IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage Delphi Discussion :

Lire le status d'une tache planifiée


Sujet :

Langage Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre expérimenté Avatar de franckcl
    Homme Profil pro
    Developpeur Delphi
    Inscrit en
    Septembre 2004
    Messages
    516
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Developpeur Delphi
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Septembre 2004
    Messages : 516
    Par défaut Lire le status d'une tache planifiée
    Bonjour,

    Ca fait un moment que je cherche sur internet sans succes.

    Je voudrais simplement lire l'état d'une tache qui est dans le planificateur de tache comme on le ferait, par exemple, en ligne de commande:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    schtasks /query /tn "\Microsoft\Windows\Time Synchronization\SynchronizeTime"
    Ce qui donne comme résultat:

    Folder: \Microsoft\Windows\Time Synchronization
    TaskName Next Run Time Status
    ======================================== ====================== ===============
    SynchronizeTime N/A Ready


    C'est donc le status "Ready" que je voudrais récupérer.
    L'autre solution serait de passer par "shellexecute" avec la commande ci-dessus mais comment lire la sortie du Shellexecute ?

    Merci pour vos suggestions.

  2. #2
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 597
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 597
    Billets dans le blog
    65
    Par défaut
    Bonjour,

    Je pencherais pour l'utilisation de WMI la clé root\Microsoft\Windows\TaskScheduler

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    procedure  GetMSFT_ScheduledTaskInfo;
    const
      WbemUser            ='';
      WbemPassword        ='';
      WbemComputer        ='localhost';
      wbemFlagForwardOnly = $00000020;
    var
      FSWbemLocator : OLEVariant;
      FWMIService   : OLEVariant;
      FWbemObjectSet: OLEVariant;
      FWbemObject   : OLEVariant;
      oEnum         : IEnumvariant;
      iValue        : LongWord;
    begin;
      FSWbemLocator := CreateOleObject('WbemScripting.SWbemLocator');
      FWMIService   := FSWbemLocator.ConnectServer(WbemComputer, 'root\Microsoft\Windows\TaskScheduler', WbemUser, WbemPassword);
      FWbemObjectSet:= FWMIService.ExecQuery('SELECT * FROM MSFT_ScheduledTask','WQL',wbemFlagForwardOnly); // avec un WHERE approprié
    mais non testé et pas sûr que ce soit la bonne clé, c'est peut-être plutôt
    root/CIMV2 et la table Win32_SheduledJob

  3. #3
    Membre Expert
    Avatar de Lung
    Profil pro
    Analyste-programmeur
    Inscrit en
    Mai 2002
    Messages
    2 704
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Analyste-programmeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 704
    Par défaut
    Citation Envoyé par franckcl Voir le message
    L'autre solution serait de passer par "shellexecute" avec la commande ci-dessus mais comment lire la sortie du Shellexecute ?
    Ou un CreateProcess et en récupérant le résultat.

    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    function TMainForm.GetConsoleText(const szCommande: String): String;
    var
       sa: TSecurityAttributes;
       ReadPipe, WritePipe: THandle;
       Start: TStartUpInfo;
       ProcessInfo: TProcessInformation;
       Buffer: Array[0..4096] of AnsiChar;
       BytesRead: DWord;
       bLecture: BOOL;
    begin
       Result := '';
       sa.nlength := SizeOf(TSecurityAttributes);
       sa.binherithandle := true;
       sa.lpsecuritydescriptor := nil;
     
       if Createpipe(ReadPipe, WritePipe, @sa, 0) then
       begin
          FillChar(Start, Sizeof(Start), #0);
          Start.cb := SizeOf(Start);
          Start.hStdOutput := WritePipe;
          Start.hStdInput := ReadPipe;
          Start.dwFlags := STARTF_USESTDHANDLES + STARTF_USESHOWWINDOW;
          Start.wShowWindow := SW_HIDE;
          if CreateProcess(nil, PChar('cmd.exe /C ' + szCommande), @sa, @sa, True, NORMAL_PRIORITY_CLASS, nil, nil, Start, ProcessInfo) then
          begin
             CloseHandle(WritePipe);
             try
                 WaitForSingleObject(ProcessInfo.hProcess, 100);
                 Application.ProcessMessages;
                repeat
                   BytesRead := 0;
                   bLecture := ReadFile(ReadPipe, Buffer[0], 255, BytesRead, nil);
                   if BytesRead > 0 then
                   begin
                      Buffer[BytesRead] := #0;
                      Result := Result + String(Buffer);
                   end;
                until(not bLecture) or (BytesRead = 0);
                WaitForSingleObject(ProcessInfo.hProcess, INFINITE);
             finally
                CloseHandle(ProcessInfo.hProcess);
                CloseHandle(ProcessInfo.hThread);
                CloseHandle(ReadPipe);
             end;
          end;
       end;
    end;
    L'urgent est fait, l'impossible est en cours, pour les miracles prévoir un délai. :bug: ___ "http://club.developpez.com/regles/#LIII-A"Écrivez dans un français correct !!

    C++Builder 5 - Delphi 6#2 Entreprise - Delphi 2007 Entreprise - Delphi 2010 Architecte - Delphi XE Entreprise - Delphi XE7 Entreprise - Delphi 10 Entreprise - Delphi 10.4.2 Entreprise - Delphi 11.3 Entreprise - Visual studio 2022
    OpenGL 2.1 - Oracle 10g - Paradox - Interbase (XE) - PostgreSQL (15.7)

  4. #4
    Membre expérimenté Avatar de franckcl
    Homme Profil pro
    Developpeur Delphi
    Inscrit en
    Septembre 2004
    Messages
    516
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Developpeur Delphi
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Septembre 2004
    Messages : 516
    Par défaut
    Réponses rapides et efficaces !
    Merci à tous et plus particulièrement à Lung pour ton exemple qui fonctionne nickel !

    Il me suffit d'effectuer ceci pour récupérer l'état:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    Var S : Srting;
    Begin
      S := GetConsoleText('schtasks /query /tn "\Microsoft\Windows\Time Synchronization\SynchronizeTime"'); 
    // renvoie: '#$D#$A'Folder: \Microsoft\Windows\Time Synchronization' (...)  =='#$D#$A'SynchronizeTime                          N/A                    Ready          '#$D#$A'
      delete(S,1,pos('SynchronizeTime',S)+15); // '                         N/A                    Ready          '#$D#$A
      S:=trim(S); // 'N/A                    Ready'
      while (length(S)>0) and (S[1]<>' ') do delete(S,1,1); // '                    Ready'
      S:=trim(S); // 'Ready'
      ShowMessage(S); // Affiche 'Ready' dans le cas présent
    End;

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Modifier l'heure d'une tache planifiée
    Par MoTUmBo dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 14/12/2005, 18h49
  2. Lire le status d'une imprimante sur le port parallèle
    Par narmataru dans le forum Linux
    Réponses: 16
    Dernier message: 21/11/2005, 14h43
  3. traitement de fichier XML dans une Tache planifiée
    Par marivi dans le forum XML/XSL et SOAP
    Réponses: 4
    Dernier message: 21/06/2005, 10h40
  4. API : créer une tache planifiée.
    Par Argonz dans le forum Windows
    Réponses: 3
    Dernier message: 05/05/2004, 14h16
  5. Créer une tache planifié (.bat ou wsh)
    Par BRAUKRIS dans le forum Windows
    Réponses: 4
    Dernier message: 18/03/2004, 17h12

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo