Diferencia entre revisiones de «Funciones de librería»

De Egeasy
Saltar a: navegación, buscar
Línea 9: Línea 9:
  
 
===[[Tratamiento de horas y fechas]]===
 
===[[Tratamiento de horas y fechas]]===
 
<blockquote style="border: 2px solid #993365; background: #FFFFFF; margin:1em 1ex 1ex 1ex; padding: 1em; text-align:left">
 
<code>'''$Fecha'''(E: expresión): {{T|fecha}}</code>
 
</blockquote>
 
 
:*'''Descripción'''<p>Convierte el resultado de una expresión a tipo fecha. El resultado de la expresión debe ser compatible con el campo fecha. El formato a seguir debe ser el siguiente dd/mm/aaaa. Si se dan los formatos dd/mm o dd se rellena con la fecha del sistema.</p>
 
 
:*'''Ejemplos'''
 
 
<blockquote style="border: 1px dashed #2F6FAB; background: #FFFFFF; margin:1em 15ex 5ex 15ex; padding: 1em; text-align:left;">
 
<code style="background: #FFFFFF">$Fecha({{STR|"23/04/2003"}})  {{COM|//devuelve 23/04/2003}}</code>
 
</blockquote>
 
 
<blockquote style="border: 1px dashed #2F6FAB; background: #FFFFFF; margin:1em 15ex 5ex 15ex; padding: 1em; text-align:left;">
 
<code style="background: #FFFFFF">$Fecha({{STR|"5/7/04"}})  {{COM|//devuelve 05/07/2004}}</code>
 
</blockquote>
 
 
<blockquote style="border: 1px dashed #2F6FAB; background: #FFFFFF; margin:1em 15ex 5ex 15ex; padding: 1em; text-align:left;">
 
<code style="background: #FFFFFF">$Fecha({{STR|"23/4"}})  {{COM|//devuelve 23/04/2005}}</code>
 
</blockquote>
 
 
<blockquote style="border: 1px dashed #2F6FAB; background: #FFFFFF; margin:1em 15ex 5ex 15ex; padding: 1em; text-align:left;">
 
<code style="background: #FFFFFF">$Fecha({{STR|"15"}})  {{COM|//devuelve 15/01/2005}}</code>
 
</blockquote>
 
 
<blockquote style="border: 2px solid #993365; background: #FFFFFF; margin:1em 1ex 1ex 1ex; padding: 1em; text-align:left">
 
<code>'''$Hoy''': {{T|fecha}}</code>
 
</blockquote>
 
 
:*'''Descripción'''<p>Devuelve la fecha del sistema.</p>
 
 
:*'''Ejemplo'''
 
 
<blockquote style="border: 1px dashed #2F6FAB; background: #FFFFFF; margin:1em 15ex 5ex 15ex; padding: 1em; text-align:left;">
 
<code style="background: #FFFFFF">$Hoy  {{COM|//devuelve 13/04/2005 por ejemplo}}</code>
 
</blockquote>
 
 
<blockquote style="border: 2px solid #993365; background: #FFFFFF; margin:1em 1ex 1ex 1ex; padding: 1em; text-align:left">
 
<code>'''$Año'''(F: {{T|fecha}}): {{T|entero}}</code>
 
</blockquote>
 
 
:*'''Descripción'''<p>Devuelve el año de una fecha dada.</p>
 
 
:*'''Ejemplo'''
 
 
<blockquote style="border: 1px dashed #2F6FAB; background: #FFFFFF; margin:1em 15ex 5ex 15ex; padding: 1em; text-align:left;">
 
<code style="background: #FFFFFF">$Año($Fecha({{STR|"13/04/2002"}}))  {{COM|//devuelve 2002}}</code>
 
</blockquote>
 
 
<blockquote style="border: 2px solid #993365; background: #FFFFFF; margin:1em 1ex 1ex 1ex; padding: 1em; text-align:left">
 
<code>'''$Mes'''(F: {{T|fecha}}): {{T|entero}}</code>
 
</blockquote>
 
 
:*'''Descripción'''<p>Devuelve el mes de una fecha dada.</p>
 
 
:*'''Ejemplo'''
 
 
<blockquote style="border: 1px dashed #2F6FAB; background: #FFFFFF; margin:1em 15ex 5ex 15ex; padding: 1em; text-align:left;">
 
<code style="background: #FFFFFF">$Mes($Fecha({{STR|"13/04/2002"}}))  {{COM|//devuelve 4}}</code>
 
</blockquote>
 
 
<blockquote style="border: 2px solid #993365; background: #FFFFFF; margin:1em 1ex 1ex 1ex; padding: 1em; text-align:left">
 
<code>'''$Dia'''(F: {{T|fecha}}): {{T|entero}}</code>
 
</blockquote>
 
 
:*'''Descripción'''<p>Devuelve el día del mes de una fecha dada.</p>
 
 
:*'''Ejemplo'''
 
 
<blockquote style="border: 1px dashed #2F6FAB; background: #FFFFFF; margin:1em 15ex 5ex 15ex; padding: 1em; text-align:left;">
 
<code style="background: #FFFFFF">$Dia($Fecha({{STR|"13/04/2002"}}))  {{COM|//devuelve 13}}</code>
 
</blockquote>
 
 
<blockquote style="border: 2px solid #993365; background: #FFFFFF; margin:1em 1ex 1ex 1ex; padding: 1em; text-align:left">
 
<code>'''$DiferenciaFechas'''(Fin: {{T|fecha}}, Inicio: {{T|fecha}}): {{T|texto}}</code>
 
</blockquote>
 
 
:*'''Descripción'''<p>Calcula la diferencia entre dos fechas dadas en días, meses y años. La fecha ''Fin'' debe ser estrictamente mayor que la fecha ''Inicio'' para que la función pueda devolver un valor.</p>
 
 
:*'''Ejemplos'''
 
 
<blockquote style="border: 1px dashed #2F6FAB; background: #FFFFFF; margin:1em 15ex 5ex 15ex; padding: 1em; text-align:left;">
 
<code style="background: #FFFFFF">$DiferenciaFechas($Fecha({{STR|"20/04/2002"}}), $Fecha({{STR|"13/04/2002"}}))  {{COM|//devuelve "7 días"}}</code>
 
</blockquote>
 
 
<blockquote style="border: 1px dashed #2F6FAB; background: #FFFFFF; margin:1em 15ex 5ex 15ex; padding: 1em; text-align:left;">
 
<code style="background: #FFFFFF">$DiferenciaFechas($Fecha({{STR|"20/05/2003"}}), $Fecha({{STR|"13/11/2002"}})) {{COM|//devuelve "6 meses y 7 días"}}</code>
 
</blockquote>
 
 
<blockquote style="border: 1px dashed #2F6FAB; background: #FFFFFF; margin:1em 15ex 5ex 15ex; padding: 1em; text-align:left;">
 
<code style="background: #FFFFFF">$DiferenciaFechas($Fecha({{STR|"30/08/2007"}}), $Fecha({{STR|"13/04/2002"}})) {{COM|//devuelve "5 años, 4 meses y 17 días"}}</code>
 
</blockquote>
 
 
<blockquote style="border: 2px solid #993365; background: #FFFFFF; margin:1em 1ex 1ex 1ex; padding: 1em; text-align:left">
 
<code>'''$DiferenciaDias'''(Fin: {{T|fecha}}, Inicio: {{T|fecha}}): {{T|entero}}</code>
 
</blockquote>
 
 
:*'''Descripción'''<p>Calcula la diferencia en días de dos fechas dadas. La fecha ''Fin'' ha de ser estrictamente mayor que la fecha ''Inicio''. Se devolverá un valor entero.</p>
 
 
:*'''Ejemplo'''
 
 
<blockquote style="border: 1px dashed #2F6FAB; background: #FFFFFF; margin:1em 15ex 5ex 15ex; padding: 1em; text-align:left;">
 
<code style="background: #FFFFFF">$DiferenciaDias($Fecha({{STR|"20/04/2002"}}),$Fecha({{STR|"13/04/2002"}})) {{COM|//devuelve 7}}</code>
 
</blockquote>
 
 
<blockquote style="border: 2px solid #993365; background: #FFFFFF; margin:1em 1ex 1ex 1ex; padding: 1em; text-align:left">
 
<code>'''$CalculaFecha'''(Inicio: {{T|fecha}}, NDias: {{T|entero}}, Hábil: {{T|lógico}}): {{T|fecha}}</code>
 
</blockquote>
 
 
:*'''Descripción'''<p>Calcula una fecha a partir de una fecha inicio que introducimos como parámetro de entrada, indicando el número de días a contar y si éstos deben ser días hábiles (verdadero) o naturales (falso). El valor devuelvo será un valor tipo fecha con la nueva fecha calculada.</p>
 
 
:*'''Ejemplos'''
 
 
<blockquote style="border: 1px dashed #2F6FAB; background: #FFFFFF; margin:1em 15ex 5ex 15ex; padding: 1em; text-align:left;">
 
<code style="background: #FFFFFF">$CalculaFecha($Fecha({{STR|"19/04/2002"}}),2,verdadero) {{COM|//devuelve 23/04/2002}}</code>
 
</blockquote>
 
 
<blockquote style="border: 1px dashed #2F6FAB; background: #FFFFFF; margin:1em 15ex 5ex 15ex; padding: 1em; text-align:left;">
 
<code style="background: #FFFFFF">$CalculaFecha($Fecha({{STR|"21/04/2002"}}),2,verdadero) {{COM|//devuelve 23/04/2002}}</code>
 
</blockquote>
 
 
<blockquote style="border: 1px dashed #2F6FAB; background: #FFFFFF; margin:1em 15ex 5ex 15ex; padding: 1em; text-align:left;">
 
<code style="background: #FFFFFF">$CalculaFecha($Fecha({{STR|"20/04/2002"}}),2,falso) {{COM|//devuelve 22/04/2002}}</code>
 
</blockquote>
 
  
 
===[[Manejo de listas de comprobación]]===
 
===[[Manejo de listas de comprobación]]===

Revisión del 11:25 20 abr 2009

Conversión de tipos

Funciones que transforman el resultado de una expresión a un tipo de dato específico.

Indicadores de tipo

Tratamiento de textos

Tratamiento de números

Tratamiento de horas y fechas

Manejo de listas de comprobación

$Lista(E: expresión): <code>lista_comprobacion</code>

  • Descripción

    Indica que el resultado de una expresión es una lista de comprobación. Muy útil cuando la expresión no es evaluada, por ejemplo por el acceso al dominio.

  • Ejemplo

$Lista([&Dominio]->[Revisión].[Documentación a requerir])

$InvertirSeleccion(L: <code>lista_comprobacion): lista_comprobacion</code>

$InvertirSeleccion(M: <code>matriz): matriz</code>

  • Descripción

    Cambia el valor de selección de todas las filas de una lista de comprobación. También admite como parámetro una matriz cuya estructura sean dos columnas, una columna lógica llamada "seleccionado" y otra de tipo texto llamada "descripción". En este caso, invertiría los valores de la columna lógica. En realidad, una lista de comprobación es una matriz con las dos columnas que hemos comentado.

  • Ejemplos

[Documentación presentada] <code>es lista_comprobacion</code>

$InvertirSeleccion([Datos generales].[Documentación presentada])

[Documentos entregados] {{PR|es}} {{T|tabla}}
       [seleccionados] {{PR|es}} {{T|logico}}
       [descripción] {{PR|es}} {{T|texto}}

---PENDIENTE---

$InvertirSeleccion($matriz([Datos generales].[Documentos entregados])</code>

<code>//[Documentos entregados] es un campo tabla con dos columnas (seleccionado, descripción)</code>

Creación de matrices

$Matriz(T: <code>texto {, A: texto}): matriz</code>

  • Descripción

    Devuelve una matriz de una columna, creada a partir de los valores introducidos como parámetros.

  • Ejemplo

$Matriz(<code>"De documentación","De requisitos","De plazo","De incidencias","De alegaciones","De denuncia","De inscripción","De actuaciones practicadas","De requisitos, libros y plazo","De plazo, documentación y requisitos")</code>

$Matriz(C: <code>tabla): matriz</code>

$Matriz(C: <code>lista_comprobacion): matriz</code>

$Matriz(C: <code>catálogo): matriz</code>

$Matriz(C: <code>colección): matriz</code>

$Matriz(C: <code>clasificador): matriz</code>

  • Descripción

    Devuelve una matriz cuyo contenido se obtendrá de los elementos que existan en los componentes tabla, catálogo, colección, clasificador o lista de comprobación.

  • Ejemplos

$Matriz([Documentación presentada])

$Matriz([Terceros].[Contenido])

$Matriz([Datos generales].[Representantes])

$Matriz([Datos generales].[Documentación presentada])

$Matriz(R: <code>enumerado): matriz</code>

$Matriz(O: <code>exportacion): matriz</code>

  • Descripción

    Devuelve una matriz cuyo contenido se obtendrá de los elementos que existan en un enumerado (recurso) o una exportación (operación).

  • Ejemplo

$Matriz([Municipios])

$Matriz([Tipos de impuestos])

$MatrizSQL(SentenciaSQL: <code>texto): matriz</code>
  • Descripción

    Devuelve una matriz cuyo contenido será el resultado de una sentencia SQL. Permite insertar el resultado de una expresión en la sentencia, prefijando con los dos puntos <<:>>. El valor interpolado tendrá la forma del tipo devuelto por la expresión.

  • Ejemplo

$MatrizSQL("select * from TC$USERS where DEPARTAMENT = 'Dirección'")

$MatrizSQL("select RRC, DRC, NAME from TR$INFORMES where DOMAIN_RRC =:[Expediente]")

Manejo de matrices

$Filtrar(M: <code>matriz, Condicion: texto): matriz</code>
  • Descripción

    Devuelve una matriz que introducimos como parámetro de la función, pero con aquellos elementos que cumplan la condición especificada en el segundo parámetro.

  • Ejemplo

$Filtrar([Municipios], "[#Isla]=[Gran Canaria]") <code>//devuelve una matriz de los municipios de una determinada isla, tras evaluar el campo [Isla]</code>

$Filtrar($Matriz[Representantes], "([#Tipo] = 'Secundario') y ([#Cargo] ='Directivo')")

$Ordenar(M: <code>matriz, Columna: texto, Ascendente: lógico): matriz</code>
  • Descripción

    Devuelve una matriz cuyas filas estarán ordenadas en función de la columna que indiquemos como parámetro. Podrán ordenarse ascendentemente (verdadero) o descendentemente (falso).

  • Ejemplo

$Ordenar([Asignaturas], <code>"[#Curso]", verdadero) //devuelve una matriz con las asignaturas ordenadas por curso de forma ascendente</code>

$EliminarFilasRepetidas(M: <code>matriz): matriz</code>
  • Descripción

    Elimina las filas repetidas de una matriz que pasamos a la función como parámetro de entrada.

  • Ejemplo

PENDIENTE

$MatrizFila(Expresion: <code>texto {, E: texto}): matriz</code>
  • Descripción

    Devuelve una matriz de una sola fila, donde los valores son obtenidos de campos definidos. La expresión corresponderá a una asignación con el nombre de la columna y a continuación la expresión de un campo donde obtener el valor. La forma de la expresión es "Nombre_columna = [Campo]"

  • Ejemplo

$MatrizFila("[Nombre] = [Denominación]->[Datos del promotor].[Promotor]")

$RenombrarColumnas(M: <code>matriz, Actual: texto, Nuevo: texto {, A: texto, N: texto}): matriz</code>
  • Descripción

    Devuelve una matriz con las columnas «Actual» renombradas por «Nuevo».

  • Ejemplo

$RenombrarColumnas(M, <code>"Cod", "Código", "Den", "Denominación") {{COM|//devuelve la matriz donde las columnas: "Cod" y "Den" se han renombrado por "Código" y "Denominación"</code>

$RenombrarColumnas(M: <code>matriz, Actual: texto, Nuevo: texto {, A: texto, N: texto}): matriz</code>
  • Descripción

    Devuelve una matriz con las columnas «Actual» renombradas por «Nuevo».

  • Ejemplo

$RenombrarColumnas(M, <code>"Cod", "Código", "Den", "Denominación") //devuelve la matriz donde las columnas: "Cod" y "Den" se han renombrado por "Código" y "Denominación"</code>

$Columnas(M: <code>matriz, Columna: texto {, C: texto}): matriz</code>
  • Descripción

    Función que devuelve una matriz con las columnas seleccionadas de otra matriz que introducimos como parámetro de entrada.

  • Ejemplo

$Columnas([Municipios], <code>"[#Municipio]", "[#CodProvincia]")</code>

$AgruparSuma(M: <code>matriz, Suma: texto, Agrupa: texto {, A: texto}): matriz</code>
  • Descripción

    Devuelve una matriz donde se agruparán las filas cuando exista una coincidencia entre los valores de las columnas «Agrupa» que se especifiquen. Al encontrar una coincidencia se sumarán los valores de las celdas «Suma» de cada coincidencia y el resultado se escribirá en la celda resultante de la columna «Suma». Se creará por tanto, una sola fila, con una columna «Suma» y la fusión de las columnas cuyos valores coincidan. La matriz devuelta sólo constará de las columnas «Agrupa» y la columna «Suma», que ha de ser numérica.

  • Ejemplo

$AgruparSuma(M, <code>"Importe", "Producto", "Categoría") //devuelve una matriz con las tres columnas donde siempre que coincida los valores del par «Producto» y «Categoría», los valores de «Importe» se suman</code>

Manejo de colecciones

$SeleccionarObjetoPorDefinicion(C: <code>colección, D: definición): contenedor</code>
  • Descripción

    Devuelve en forma de matriz el primer contenedor de una colección que cumple la definición.

  • Ejemplo

$SeleccionarObjetoPorDefinicion([Contenido], <code>"[Hoja contable]") //devuelve la primera hoja contable que encuentre en la colección especificada</code>

$SeleccionarObjetosPorDefinicion(C: <code>colección, D: definición): matriz</code>
  • Descripción

    Devuelve una matriz con todos aquellos objetos de la colección que cumplan la definición.

  • Ejemplo

$SeleccionarObjetosPorDefinicion([Contenido], <code>"[Hoja contable]") //devuelve todas las hojas contables contenidas en la colección</code>