Herramientas → Escenarios
Raccourcis clavier/ /souris</ /small>
Cerebro real de la automatización del hogar, los escenarios permiten interactuar con el mundo real de una manera inteligente.
Allí encontrará la lista de escenarios de su Jeedom, así como las funcionalidades para administrarlos en el mejor de los casos :
Encontrarás en esta parte lista de escenarios que creaste. Se clasifican según su banda, posiblemente definido para cada uno de ellos. Cada escenario se muestra con su nombre y su objeto padre. EL escenarios atenuados son los que están deshabilitados.
Consejo
Puede abrir un escenario haciendo :
- Haga clic en uno de ellos.
- Ctrl Clic o Clic Center para abrirlo en una nueva pestaña del navegador.
Tiene un motor de búsqueda para filtrar la visualización de escenarios. La tecla Escape cancela la búsqueda. A la derecha del campo de búsqueda, se encuentran tres botones en varios lugares de Jeedom :
Una vez en la configuración de un escenario, tiene un menú contextual con clic derecho en las pestañas del escenario. También puede usar Ctrl Click o Click Center para abrir directamente otro escenario en una nueva pestaña del navegador.
Después de hacer clic en Agregar, debes elegir el nombre de tu escenario. Luego se lo redirige a la página de sus parámetros generales. Antes de eso, en la parte superior de la página, hay algunas funciones útiles para administrar este escenario :
Consejos
Dos herramientas también serán invaluables para usted en la configuración de escenarios : > - Las variables, visibles en Herramientas → Variables > - El probador de expresiones, accesible por Herramientas → Probador de expresiones
A Ctrl Haga clic en el botón ejecutar le permite guardar, ejecutar y mostrar directamente el registro del escenario (si el nivel de registro no es Ninguno).
En la pestaña General, encontramos los principales parámetros del escenario :
IMPORTANTE
El lanzamiento múltiple funciona por segundo, es decir que si tienes 2 lanzamientos en el mismo segundo sin marcar la casilla, aún habrá 2 lanzamientos del escenario (aunque no debería). Asimismo, durante varios lanzamientos en el mismo segundo, algunos lanzamientos pueden perder las etiquetas. Conclusión es ABSOLUTAMENTE necesario evitar múltiples lanzamientos en el mismo segundo.
Consejo
Las condiciones ahora se pueden ingresar en modo activado. Por ejemplo :
#[Garage][Open Garage][Ouverture]# == 1
Atención : puede tener un máximo de 28 disparadores / programación para un escenario.
Modo de punta programado
El modo programado usa sintaxis Cron. Por ejemplo, puede ejecutar un escenario cada 20 minutos con
*/20 * * * *
, o a las 5 de la mañana para arreglar multitud de cosas del día con0 5 * * *
. EL ? a la derecha de un programa le permite configurarlo sin ser un especialista en sintaxis de Cron. También es posible poner una hora de lanzamiento en el formatoGi
(hora sin cero ni minutos iniciales, ejemplo para09h15
=>915
o para23h40
=>2340
). Este tiempo puede ser el resultado de un cálculo (mediante un comando o una etiqueta), por ejemplo :#sunset# + 10
para un lanzamiento 10 minutos después del atardecer. Tenga en cuenta que para un lanzamiento 1h30 después del atardecer debe poner#sunset# + 130
. Tenga en cuenta que cuando utilice una sintaxis distinta a cron, jeedom no podrá proporcionarle las fechas de los lanzamientos anteriores o siguientes.
Aquí es donde construirás tu escenario. Después de crear el escenario, su contenido está vacío, por lo que hará … nada. Tienes que empezar con Agregar bloque, con el botón de la derecha. Una vez que se ha creado un bloque, puede agregar otro bloquear o un acción.
Para mayor comodidad y no tener que reordenar constantemente los bloques en el escenario, se agrega un bloque después del campo en el que se encuentra el cursor del mouse. Por ejemplo, si tiene diez bloques y hace clic en la condición SI del primer bloque, el bloque agregado se agregará después de este bloque, en el mismo nivel. Si no hay ningún campo activo, se agregará al final del escenario.
Consejo
En condiciones y acciones, es mejor favorecer comillas simples (‘) en lugar de dobles (“).
Consejo
Un Ctrl Shift Z o Ctrl Shift Y le permite’Cancelar o de rehacer una modificación (adición de acción, bloqueo…).
Aquí están los diferentes tipos de bloques disponibles :
Cada bloque tiene sus opciones para manejarlos mejor :
Para las condiciones, Jeedom trata de hacer posible escribirlas tanto como sea posible en lenguaje natural sin dejar de ser flexible.
NO use [] en pruebas de condición, solo son posibles paréntesis ().
Hay tres botones disponibles a la derecha de este tipo de bloque para seleccionar un elemento para probar :
Nota
En bloques de tipo Si / Entonces / De lo contrario, las flechas circulares a la izquierda del campo de condición permiten activar o no la repetición de acciones si la evaluación de la condición da el mismo resultado que durante la evaluación previa. SI expresión != 0 es equivalente a SI expresión y SI expresión == 0 es equivalente a SI no expresión
Consejo
Hay una lista de etiquetas que permiten el acceso a las variables desde el escenario u otro, o por la hora, la fecha, un número aleatorio, … Vea a continuación los capítulos sobre comandos y etiquetas.
Una vez que se completa la condición, debe usar el botón "Agregar" a la izquierda para agregar un nuevo bloquear o un acción en el bloque actual.
El bloque de código le permite ejecutar código php. Por lo tanto, es muy potente pero requiere un buen conocimiento del lenguaje php.
cmd::byString($string);
: Devuelve el objeto de comando correspondiente.
$string
: Enlace al pedido deseado : #[objet][equipo][commande]#
(Ex : #[Appartement][Alarme][Activo]#
)cmd::byId($id);
: Devuelve el objeto de comando correspondiente.
$id
: ID de pedido.$cmd->execCmd($options = null);
: Ejecute el comando y devuelva el resultado.
$options
: Opciones para la ejecución del comando (puede ser específico del complemento). Opciones básicas (subtipo de comando) :
message
: $option = array('title' => 'titre du mensaje , 'message' => 'Mon message');
color
: $option = array('color' => 'couleur en hexadécimal');
slider
: $option = array('slider' => 'valeur voulue de 0 à 100');
log::add('filename','level','message');
filename
: Nombre del archivo de registro.level
: [depuración], [información], [error], [evento].message
: Mensaje para escribir en los registros.$scenario->getName();
: Devuelve el nombre del escenario actual.$scenario->getGroup();
: Devuelve el grupo de escenarios.$scenario->getIsActive();
: Devuelve el estado del escenario.$scenario->setIsActive($active);
: Le permite activar o no el escenario.
$active
: 1 activo, 0 no activo.$scenario->running();
: Se usa para averiguar si el escenario se está ejecutando o no (verdadero / falso).$scenario->save();
: Guardar cambios.$scenario->setData($key, $value);
: Guardar un dato (variable).
$key
: clave de valor (int o string).$value
: valor para almacenar (int
, string
, array
O object
).$scenario->getData($key);
: Obtener datos (variable).
$key => 1
: clave de valor (int o string).$scenario->removeData($key);
: Eliminar datos.$scenario->setLog($message);
: Escribe un mensaje en el registro del script.$scenario->persistLog();
: Forzar la escritura del registro (de lo contrario, se escribe solo al final del escenario). Tenga cuidado, esto puede retrasar un poco el escenario.Consejo
Adición de una función de búsqueda en el bloque de Código : Investigar : Ctrl + F luego Enter, Siguiente resultado : Ctrl + G, resultado anterior : Ctrl + Mayús + G
Escenarios : Pequeños códigos con amigos
El bloque de comentarios actúa de manera diferente cuando está oculto. Sus botones a la izquierda desaparecen, así como el título del bloque, y reaparecen al pasar el cursor. Del mismo modo, la primera línea del comentario se muestra en negrita. Esto permite que este bloque se utilice como una separación puramente visual dentro del escenario.
Las acciones agregadas a los bloques tienen varias opciones :
Consejo
Dependiendo del comando seleccionado, se pueden mostrar diferentes campos adicionales.
Hay desencadenantes específicos (distintos de los proporcionados por los comandos) :
#start#
: Activado al (re) inicio de Jeedom.#begin_backup#
: Evento enviado al inicio de una copia de seguridad.#end_backup#
: Evento enviado al final de una copia de seguridad.#begin_update#
: Evento enviado al inicio de una actualización.#end_update#
: Evento enviado al final de una actualización.#begin_restore#
: Evento enviado al inicio de una restauración.#end_restore#
: Evento enviado al final de una restauración.#user_connect#
: Inicio de sesión de usuario#variable(nom_variable)#
: Cambiar el valor de la variable name_name.#genericType (GENÉRICO, #[Object]#)#
: Cambio de un comando de información de tipo GENÉRICO genérico, en el objeto Objeto.#new_eqLogic#
: Evento enviado al crear un nuevo equipo, tienes en las etiquetas id (id del equipo creado), name (nombre del equipo creado) y eqType (tipo/plugin del equipo creado))También puede activar un escenario utilizando la API HTTP descrita aquí.
Puede utilizar cualquiera de los siguientes símbolos para realizar comparaciones en condiciones :
==
: Igual a.>
: Estrictamente mayor que.>=
: Mayor o igual que.<
: Estrictamente menor que.<=
: Menor o igual que.!=
: Diferente de, no es igual a.matches
: Contiene. Ex : [Salle de bain][Hydrometrie][etat] matches "/ /humide/ /"
.not(… matches …)
: No contiene. Ex : not([Salle de bain][Hydrometrie][etat] matches "/ /humide/ /")
.Puedes combinar cualquier comparación con los siguientes operadores :
Ya sea que combine comparativas en diferentes equipos o en el mismo, siempre es necesario indicar el equipo.
[Salle de bain][Hydrometrie][température] >= 18 YY [Salle de bain][Hydrometrie][température] <= 22
YY
: Y. Atención, el uso de : ET
/ / et
/ / AND
/ / and
no se recomienda, en algunos casos puede funcionar pero con algunas funciones de php no funcionará.||
: O. Atención, el uso de : OU
/ / ou
/ / OR
/ / or
no se recomienda, en algunos casos puede funcionar pero con algunas funciones de php no funcionará.xor
: o exclusivo. Atención, el uso de : XOR
/ / ^
no se recomienda, en algunos casos puede funcionar pero con algunas funciones de php no funcionará.Una etiqueta se reemplaza durante la ejecución del escenario por su valor. Puedes usar las siguientes etiquetas :
Consejo
Para mostrar los ceros iniciales, use la función Fecha (). Ver aquí.
#seconde#
: Segundo actual (sin ceros a la izquierda, ej : 6 para 08:07:06).#hour#
: Hora actual en formato de 24 h (sin ceros a la izquierda)). Ex : 8 para 08:07:06 o 17 para 17:15.#hour12#
: Hora actual en formato de 12 horas (sin ceros a la izquierda)). Ex : 8 para 08:07:06.#minute#
: Minuto actual (sin ceros a la izquierda). Ex : 7 para 08:07:06.#day#
: Día actual (sin ceros a la izquierda)). Ex : 6 para 06/07/2017.#month#
: Mes actual (sin ceros a la izquierda). Ex : 7 para 06/07/2017.#year#
: Año actual.#time#
: Hora y minuto actual. Ex : 1715 para las 5.15 p.m.#timestamp#
: Número de segundos desde el 1 de enero de 1970.#date#
: Día y mes. Atención, el primer número es el mes. Ex : 1215 para el 15 de diciembre.#week#
: Número de semana.#sday#
: Nombre del día de la semana. Ex : SÁBADO.#nday#
: Número de día de 0 (domingo) a 6 (sábado)).#smonth#
: Nombre del mes. Ex : Enero.#IP#
: IP interna de Jeedom.#hostname#
: Nombre de la máquina Jeedom.#jeedomName#
: Nombre de Jeedom.#trigger#
: Puede ser :
api
si el lanzamiento fue activado por la API,TYPEcmd
si el inicio fue activado por un comando, con TYPE reemplazó la identificación del complemento (por ejemplo, virtualCmd),schedule
si se inició programando,user
si se inició manualmente,start
para un lanzamiento al inicio de Jeedom.#trigger_id#
: Si es un comando el que desencadenó el escenario, entonces esta etiqueta tiene el valor de la identificación del comando que lo desencadenó. Ejemplo : #trigger_id# == 19
#trigger_name#
: Si es un comando el que desencadenó el escenario, entonces esta etiqueta tiene el valor del nombre del comando (en el formato [objeto][equipo][comando]). Ejemplo : #trigger_name# == '[cuisine][lumiere][etat]'
#trigger_value#
: Si es un comando que desencadenó el escenario, entonces esta etiqueta tiene el valor del comando que desencadenó el escenario. Consejo: si desea conocer el valor actual del comando que desencadenó el escenario (y no su valor en el momento de la activación), puede utilizar : ##trigger_id##
(doble #)#latitude#
: Le permite recuperar la información de latitud ingresada en la configuración de jeedom#longitude#
: Le permite recuperar la información de longitud ingresada en la configuración de jeedom#altitude#
: Le permite recuperar la información de altitud ingresada en la configuración de jeedom#sunrise#
: Le permite recuperar la hora del amanecer siempre que se ingresen la latitud y la longitud en la configuración de jeedom#sunset#
: Le permite recuperar la hora del atardecer siempre que se ingresen la latitud y la longitud en la configuración de jeedomTambién tiene las siguientes etiquetas adicionales si su escenario fue desencadenado por una interacción :
IMPORTANTE
Cuando una interacción desencadena un escenario, se ejecuta necesariamente en modo rápido. Entonces, en el hilo de interacción y no en un hilo separado.
Hay varias funciones disponibles para el equipo :
average(commande,période)
Y averageBetween(commande,start,end)
: Indique el promedio del pedido durante el período (período=[mes, día, hora, min] o expresión PHP) o entre los 2 terminales solicitados (en el formulario Y-m-d H:i:s
O Expresión PHP).
averageTemporal(commande,période)
Y averageTemporalBetween(commande,start,end)
: Indique el promedio de los valores del pedido ponderado por su duración de existencia durante el período (período=[mes, día, hora, min] o expresión PHP) o entre los 2 terminales solicitados (en el formulario Y-m-d H:i:s
O Expresión PHP).
min(commande,période)
Y minBetween(commande,start,end)
: Dar el pedido mínimo durante el período (período=[mes, día, hora, min] o expresión PHP) o entre los 2 terminales solicitados (en el formulario Y-m-d H:i:s
O Expresión PHP).
max(commande,période)
Y maxBetween(commande,start,end)
: Dar el máximo del pedido durante el período (período=[mes, día, hora, min] o expresión PHP) o entre los 2 terminales solicitados (en el formulario Y-m-d H:i:s
O Expresión PHP).
duration(commande, valeur, période)
Y durationbetween(commande,valeur,start,end)
: Indique la duración en minutos durante los cuales el equipo tuvo el valor elegido durante el período (período=[mes, día, hora, min] o expresión PHP) o entre los 2 terminales solicitados (en el formulario Y-m-d H:i:s
O Expresión PHP).
statistics(commande,calcul,période)
Y statisticsBetween(commande,calcul,start,end)
: Proporcione el resultado de diferentes cálculos estadísticos (suma, recuento, estándar, varianza, promedio, mínimo, máximo) durante el período (período=[mes, día, hora, min] o expresión PHP) o entre los 2 terminales solicitados (en el formulario Y-m-d H:i:s
O Expresión PHP).
tendance(commande,période,seuil)
: Da la tendencia del pedido durante el período (período=[mes, día, hora, min] o expresión PHP).
stateDuration(commande)
: Da la duración en segundos desde el último cambio de valor.
-1 : No existe historial o el valor no existe en el historial.
-2 : El pedido no está registrado.
lastChangeStateDuration(commande,valeur)
: Da la duración en segundos desde el último cambio de estado al valor pasado en el parámetro.
-1 : No existe historial o el valor no existe en el historial.
-2 El pedido no está registrado
lastStateDuration(commande,valeur)
: Da la duración en segundos durante los cuales el equipo ha tenido el último valor elegido.
-1 : No existe historial o el valor no existe en el historial.
-2 : El pedido no está registrado.
age(commande)
: Da la edad en segundos del valor del comando (collecDate
)
-1 : El comando no existe o no es de tipo información.
stateChanges(commande,[valeur], période)
Y stateChangesBetween(commande, [valeur], start, end)
: Da el número de cambios de estado (hacia un cierto valor si se indica, o si no se indica en comparación con su valor actual) durante el período (período=[mes, día, hora, min] o expresión PHP) o entre los 2 terminales solicitados (en el formulario Y-m-d H:i:s
O Expresión PHP).
lastBetween(commande,start,end)
: Da el último valor registrado para el dispositivo entre los 2 terminales solicitados (en el formulario Y-m-d H:i:s
O Expresión PHP).
variable(mavariable,valeur par défaut)
: Recupera el valor de una variable o el valor deseado por defecto.
genericType (GENÉRICO, #[Object]#)
: Recupera la suma de la información GENÉRICA del tipo genérico en el objeto Objeto.
scenario(scenario)
: Devuelve el estado del escenario.
1 : En curso,
0 : Detenido,
-1 : Discapacitado,
-2 : El escenario no existe,
-3 : El estado no es consistente.
Para tener el nombre "humano" del escenario, puede usar el botón dedicado a la derecha de la búsqueda del escenario.
lastScenarioExecution(scenario)
: Da la duración en segundos desde el último lanzamiento del escenario.
0 : El escenario no existe
collectDate(cmd,[format])
: Devuelve la fecha de la última recopilación de datos para el comando colocado como parámetro, el segundo parámetro opcional se usa para especificar el formato de retorno (detalles aquí).
-1 : No se pudo encontrar el comando,
-2 : El comando no es de tipo info.
valueDate(cmd,[format])
: Devuelve la fecha del último valor conocido para el comando colocado como parámetro, el segundo parámetro opcional se usa para especificar el formato de retorno (detalles aquí).
-1 : No se pudo encontrar el comando,
-2 : El comando no es de tipo info.
eqEnable(equipement)
: Devuelve el estado del equipo.
-2 : No se puede encontrar el equipo,
1 : El equipo esta activo,
0 : El equipo esta inactivo.
value(cmd)
: Devuelve el valor de un pedido si Jeedom no lo proporciona automáticamente (caso al almacenar el nombre del pedido en una variable)
tag(montag,[defaut])
: Se usa para recuperar el valor de una etiqueta o el valor predeterminado si no existe.
name(type,commande)
: Se utiliza para recuperar el nombre del pedido, equipo u objeto. Amable : cmd, eqLogic u objeto.
lastCommunication(equipment,[format])
: Devuelve la fecha de la última retroalimentación de información para el equipo dada en el parámetro, el segundo parámetro opcional se usa para especificar el formato de devolución (detalles aquí). Un retorno de -1 significa que no se puede encontrar el equipo. La fecha de última información se calcula en relación con el tipo de información orden y su fecha de recogida.
color_gradient(couleur_debut,couleur_fin,valuer_min,valeur_max,valeur)
: Devuelve un color calculado en relación con un valor en el intervalo color_start / color_end. El valor debe estar entre min_value y max_value.
Los períodos e intervalos de estas funciones también se pueden usar con Expresiones PHP como por ejemplo :
Now
: AHORA.Today
: 00:00 hoy (permite, por ejemplo, obtener resultados para el día si entre Today
Y Now
).Last Monday
: el lunes pasado a las 00:00.5 days ago
: Hace 5 dias.Yesterday noon
: ayer mediodia.Aquí hay ejemplos prácticos para comprender los valores devueltos por estas diferentes funciones :
Zócalo con valores : | 000 (por 10 minutos) 11 (por 1 hora) 000 (por 10 minutos) |
---|---|
average(prise,période) |
Devuelve el promedio de 0 y 1 (puede |
ser influenciado por las encuestas) | |
averageBetween(#[Salle de bain][Hydrometrie][Humidité]#,2015-01-01 00:00:00,2015-01-15 00:00:00) |
Devuelve el pedido promedio entre el 1 de enero de 2015 y el 15 de enero de 2015 |
min(prise,période) |
Devuelve 0 : el tapón se apagó durante el período |
minBetween(#[Salle de bain][Hydrometrie][Humidité]#,2015-01-01 00:00:00,2015-01-15 00:00:00) |
Devuelve el pedido mínimo entre el 1 de enero de 2015 y el 15 de enero de 2015 |
max(prise,période) |
Devuelve 1 : el enchufe estaba bien iluminado en el período |
maxBetween(#[Salle de bain][Hydrometrie][Humidité]#,2015-01-01 00:00:00,2015-01-15 00:00:00) |
Devuelve el máximo del pedido entre el 1 de enero de 2015 y el 15 de enero de 2015 |
duration(prise,1,période) |
Devuelve 60 : el enchufe estuvo encendido (a 1) durante 60 minutos en el período |
durationBetween(#[Salon][Prise][Etat]#,0,Last Monday,Now) |
Devuelve la duración en minutos durante la cual el socket estuvo apagado desde el lunes pasado. |
statistics(prise,count,période) |
Devuelve 8 : hubo 8 escaladas en el período |
tendance(prise,période,0.1) |
Devuelve -1 : tendencia a la baja |
stateDuration(prise) |
Devuelve 600 : el enchufe ha estado en su estado actual durante 600 segundos (10 minutos) |
lastChangeStateDuration(prise,0) |
Devuelve 600 : el zócalo se apagó (cambie a 0) por última vez hace 600 segundos (10 minutos) |
lastChangeStateDuration(prise,1) |
Devuelve 4200 : el zócalo se encendió (cambie a 1) por última vez hace 4200 segundos (1h10) |
lastStateDuration(prise,0) |
Devuelve 600 : el enchufe ha estado apagado por 600 segundos (10 minutos) |
lastStateDuration(prise,1) |
Devuelve 3600 : el zócalo se encendió por última vez durante 3600 segundos (1 hora) |
stateChanges(prise,période) |
Devuelve 3 : el conector ha cambiado de estado 3 veces durante el período (si el comando de información es de tipo binario) |
stateChanges(prise,0,période) |
Devuelve 2 : el zócalo se ha apagado (yendo a 0) dos veces durante el período |
stateChanges(prise,1,période) |
Devuelve 1 : el enchufe se enciende (cambie a 1) una vez durante el período |
lastBetween(#[Salle de bain][Hydrometrie][Température]#,Yesterday,Today) |
Devuelve la última temperatura registrada ayer. |
variable(plop,10) |
Devuelve el valor de la variable plop o 10 si está vacía o no existe |
scenario(#[Salle de bain][Lumière][Auto]#) |
Devuelve 1 en progreso, 0 si se detiene y -1 si está desactivado, -2 si el escenario no existe y -3 si el estado no es consistente |
lastScenarioExecution(#[Salle de bain][Lumière][Auto]#) |
Devuelve 300 si el escenario se inició por última vez hace 5 minutos |
collectDate(#[Salle de bain][Hydrometrie][Humidité]#) |
Devuelve 2021-02-14 17:50:12 |
valueDate(#[Salle de bain][Hydrometrie][Humidité]#) |
Devuelve 2021-02-14 17:45:12 |
eqEnable(#[Aucun][Basilique]#) |
Devuelve -2 si no se encuentra el equipo, 1 si el equipo está activo y 0 si está inactivo |
tag(montag,toto) |
Devuelve el valor de “montag” si existe, de lo contrario devuelve el valor “toto” |
name(eqLogic,#[Salle de bain][Hydrometrie][Humidité]#) |
Hidrometría de devoluciones |
También se puede usar una caja de herramientas de funciones genéricas para realizar conversiones o cálculos :
rand(1,10)
: Dar un número aleatorio del 1 al 10.randText(texte1;texte2;texte…..)
: Le permite devolver uno de los textos al azar (separe los textos por uno; ). No hay límite en el número de textos.randomColor(min,max)
: Da un color aleatorio entre 2 límites (0 => rojo, 50 => verde, 100 => azul).trigger(commande)
: Le permite descubrir el desencadenante del escenario o saber si es el comando pasado como parámetro el que desencadenó el escenario. => En desuso, es mejor usar la etiqueta #trigger#triggerValue()
: Se usa para averiguar el valor del desencadenante del escenario. => En desuso, es mejor usar la etiqueta #triggerValue#round(valeur,[decimal])
: Redondea arriba, número [decimal] de lugares decimales después del punto decimal.odd(valeur)
: Le permite saber si un número es impar o no. Devuelve 1 si es impar 0 de lo contrario.median(commande1,commande2….commandeN)
: Devuelve la mediana de los valores.avg(commande1,commande2….commandeN)
: Devuelve el promedio de los valores.time_op(time,value)
: Le permite realizar operaciones a tiempo, con tiempo = tiempo (ej : 1530) y valor = valor para sumar o restar en minutos.time_between(time,start,end)
: Se usa para probar si un tiempo está entre dos valores con time=temps
(Ex : 1530), start=temps
, end=temps
. Los valores iniciales y finales pueden estar a caballo entre la medianoche.time_diff(date1,date2[,format, round])
: Se usa para descubrir la diferencia entre dos fechas (las fechas deben estar en el formato AAAA / MM / DD HH:MM:SS). Por defecto, el método devuelve la diferencia en día (s). Puedes preguntarlo en segundos (s), minutos (m), horas (h). Ejemplo en segundos time_diff(2019-02-02 14:55:00,2019-02-25 14:55:00,s)
. La diferencia se devuelve en absoluto, a menos que especifique f
(sf
, mf
, hf
, df
). También puedes usar dhms
quien no devolverá ejemplo 7j 2h 5min 46s
. El parámetro de redondeo opcional se redondea a x decimales (2 por defecto). Ex: time_diff(2020-02-21 20:55:28,2020-02-28 23:01:14,df, 4)
.formatTime(time)
: Formatea el retorno de una cadena #time#
.floor(time/ /60)
: Convierte segundos a minutos o minutos a horas (floor(time/ /3600)
por segundos a horas).convertDuration(secondes)
: Convierte segundos a d / h / min / s.Y ejemplos prácticos :
Ejemplo de funcion | Resultado devuelto |
---|---|
randText(il fait #[salon][oeil][température]#;La température est de #[salon][oeil][température]#;Actuellement on a #[salon][oeil][température]#) |
la función devolverá uno de estos textos al azar en cada ejecución. |
randomColor(40,60) |
Devuelve un color aleatorio cercano al verde. |
round(#[Salle de bain][Hydrometrie][Humidité]# / / 10) |
Devuelve 9 si el porcentaje de humedad y 85 |
odd(3) |
Devuelve 1 |
median(15,25,20) |
Devuelve 20 |
avg(10,15,18) |
Devuelve 14.3 |
time_op(#time#, -90) |
si son las 4:50 p.m., regrese : 1 650-1 130 = 1520 |
formatTime(1650) |
Devuelve 4:50 p.m |
floor(130/ /60) |
Devuelve 2 (minutos si 130 s, u horas si 130 m) |
convertDuration(3600) |
Devuelve 1h 0min 0s |
convertDuration(duration(#[Chauffage][Module chaudière][Etat]#,1, first day of this month)*60) |
Devuelve el tiempo de encendido en días / horas / minutos del tiempo de transición al estado 1 del módulo desde el primer día del mes |
sun(elevation)
: Da en ° la elevación del sol (ojo, debes haber ingresado tus coordenadas geográficas en la configuración de jeedom)sun(azimuth)
: Da en ° el acimut del sol (ojo, debes haber ingresado tus coordenadas geográficas en la configuración de jeedom)Además de los comandos de automatización del hogar, tiene acceso a las siguientes acciones :
Esta funcionalidad le permite transformar un escenario en una plantilla para, por ejemplo, aplicarlo a otro Jeedom.
Haciendo clic en el botón Plantilla en la parte superior de la página, abre la ventana de administración de plantillas.
A partir de ahí, tienes la posibilidad :
Al hacer clic en una plantilla, puede :
A continuación, tiene la parte para aplicar su plantilla al escenario actual.
Dado que de un Jeedom a otro o de una instalación a otra, los comandos pueden ser diferentes, Jeedom le solicita la correspondencia de los comandos entre los presentes durante la creación de la plantilla y los presentes en el hogar. Solo tiene que completar la correspondencia de las órdenes y luego aplicar.
IMPORTANTE
Agregar funciones PHP está reservado para usuarios avanzados. El más mínimo error puede ser fatal para su Jeedom.
Vaya a la configuración de Jeedom, luego OS / DB e inicie el editor de archivos.
Vaya a la carpeta de datos, luego php y haga clic en el archivo user.function.class.php.
Es en esto clase que puedes agregar tus funciones, allí encontrarás un ejemplo de una función básica.
IMPORTANTE
Si tiene alguna inquietud, siempre puede volver al archivo original copiando el contenido de
user.function.class.sample.php
Enuser.function.class.php