Id. De evento de Windows para cambio de nivel de batería

9

Necesito crear una tarea en TS basada en el cambio de nivel de batería. Digamos que mi batería cae del 67% al 66% . ¿Cómo puedo ejecutar una tarea basada en este evento? ¿Windows registra esto? No pude encontrar esta información en ningún lado.

Adiviname esto
fuente
¿Qué versión de Windows?
DavidPostill
Windows 10 (y preferiblemente W7 también)
RiddleMeThis

Respuestas:

11

Necesito crear una tarea en el Programador de tareas basado en el cambio de nivel de batería

Windows no registra este tipo de detalles como eventos. Sin embargo, puede usar algo como el archivo por lotes a continuación y crear un evento personalizado.


Battery.cmd

Este archivo por lotes supervisa el porcentaje de carga actual de la batería y crea un evento definido por el usuario si la carga cae por debajo de un valor umbral definido por el usuario.

@echo off
setlocal EnableDelayedExpansion
rem set threshold value
set _threshold=82
:start
rem get the battery charge
rem use findstr to strip blank lines from wmic output
for /f "usebackq skip=1 tokens=1" %%i in (`wmic Path Win32_Battery Get EstimatedChargeRemaining ^| findstr /r /v "^$"`) do (
  set _charge=%%i
  echo !_charge!
  if !_charge! lss !_threshold! (
    echo threshold reached
    rem create a custom event in the application event log
    rem requires administrator privileges 
    eventcreate /l APPLICATION /t WARNING /ID 999 /D "Battery charge has dropped"
    goto :done
    ) else (
    rem wait for 10 minutes then try again
    timeout /t 600 /nobreak
    goto :start
    )
  )
:done
endlocal

Notas:

  • El Eventcreatecomando funciona en Windows XP hasta Windows 10 inclusive, requiere privilegios de administrador para funcionar
  • Establecer _thresholdsegún sea necesario
  • Si la batería cae por debajo de este valor 999, se generará un evento con ID en el registro de eventos de APLICACIÓN con la descripciónBattery charge has dropped
  • Modifique el eventcreatecomando según sea necesario para su situación.
  • Modifique el timeoutretraso según sea necesario para su situación.

Salida de ejemplo:

Mi batería actualmente tiene una carga del 81%. Puse el umbral a 82. Esto es lo que sucede cuando corro Battery.cmd:

> battery
81
threshold reached

SUCCESS: An event of type 'WARNING' was created in the 'APPLICATION' log with 'EventCreate' as the source.

Y aquí está la nueva entrada en el registro de eventos:

ingrese la descripción de la imagen aquí


sintaxis eventcreate

EVENTCREATE [/S system [/U username [/P [password]]]] /ID eventid
            [/L logname] [/SO srcname] /T type /D description

Description:
    This command line tool enables an administrator to create
    a custom event ID and message in a specified event log.

Parameter List:
    /S    system           Specifies the remote system to connect to.

    /U    [domain\]user    Specifies the user context under which
                           the command should execute.

    /P    [password]       Specifies the password for the given
                           user context. Prompts for input if omitted.

    /L    logname          Specifies the event log to create
                           an event in.

    /T    type             Specifies the type of event to create.
                           Valid types: SUCCESS, ERROR, WARNING, INFORMATION.

    /SO   source           Specifies the source to use for the
                           event (if not specified, source will default
                           to 'eventcreate'). A valid source can be any
                           string and should represent the application
                           or component that is generating the event.

    /ID   id               Specifies the event ID for the event. A
                           valid custom message ID is in the range
                           of 1 - 1000.

    /D    description      Specifies the description text for the new event.

    /?                     Displays this help message.


Examples:
    EVENTCREATE /T ERROR /ID 1000
        /L APPLICATION /D "My custom error event for the application log"

    EVENTCREATE /T ERROR /ID 999 /L APPLICATION
        /SO WinWord /D "Winword event 999 happened due to low diskspace"

    EVENTCREATE /S system /T ERROR /ID 100
        /L APPLICATION /D "Custom job failed to install"

    EVENTCREATE /S system /U user /P password /ID 1 /T ERROR
        /L APPLICATION /D "User access failed due to invalid user credentials"

Otras lecturas

DavidPostill
fuente
¡Realmente me gusta esto! Desde su POV, ¿es mejor crear eventos y ejecutar tareas basadas en eventos (por ejemplo, script de PS)? O ... modifique este script para ejecutar mi script PS, si el nivel de batería cae en un 1%. Supuse que Windows está creando eventos para el cambio de nivel de batería. No pensé en este enfoque, que podría ser mejor.
RiddleMeThis
1
@MiHa Depende de ti. Lo que sea más fácil de entender y mantener :)
DavidPostill
6

Hay un Microsoft-Windows-Batteryproveedor ETW con BatteryPercentRemainingevento con ID 13. Puede codificar un proyecto que use TraceEvent para crear un escucha en tiempo real para este Microsoft-Windows-Batteryproveedor. El evento tiene las entradas RemainingPercentagepara mostrar el estado y PercentageChangever el cambio:

ingrese la descripción de la imagen aquí

Cuando vea este evento y vea el -1cambio PercentageChange, ejecute el programa que desee.

magicandre1981
fuente
2

OK, el script proporcionado por DavidPostill no funciona. Es un pequeño script agradable, pero el código es errático u obsoleto.

Aquí está el fijo:

@echo off
setlocal EnableDelayedExpansion
rem set threshold value
set _threshold=30
:start
rem get the battery charge
rem use findstr to strip blank lines from wmic output
for /f "usebackq skip=1 tokens=1" %%i in (`wmic Path Win32_Battery Get EstimatedChargeRemaining ^| findstr /r /v "^$"`) do (
  set _charge=%%i
  echo !_charge!
  if !_charge! lss !_threshold! (
    echo threshold reached
    rem create a custom event in the application event log
    rem requires administrator privileges
    eventcreate /l APPLICATION /t WARNING /ID 999 /D "Battery charge has dropped below the threshold."
    goto :done
  ) else (
    rem wait for 1 minute then try again
    timeout /t 60 /nobreak
    goto :start
  )
)
:done
endlocal

Sugerí esta edición en la respuesta de DavidPostill, pero no sé por qué no fue aprobada ...

AneesAhmed777
fuente
Me puso en el camino correcto, por eso acepté su respuesta, ¡pero muchas gracias! para tu guión fijo.
RiddleMeThis
Mientras arreglaba el código, me di cuenta de lo erróneo y erróneo que findstres ... ¡Qué lástima! En serio, Microsoft? Estoy impresionado por el pequeño truco sucio de DavidPostill para hacer el trabajo.
AneesAhmed777
0

Hay una manera mucho más fácil de verificar el nivel de la batería. En el área de navegación, simplemente coloque el mouse sobre el icono de la batería y le dará un porcentaje.

Gary Weinstein
fuente
Sí, pero eso es realmente lo que no quería ... quería controlar el nivel de la batería automáticamente y se basan en el nivel de la batería hacer algunas cosas (de nuevo de forma automática)
RiddleMeThis
Por favor lea la pregunta otra vez cuidadosamente. Su respuesta no responde a la pregunta original.
DavidPostill