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

Scripts/Batch Discussion :

Problème avec date et heure [Batch]


Sujet :

Scripts/Batch

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    683
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 683
    Points : 237
    Points
    237
    Par défaut Problème avec date et heure
    Bonjour,

    J'ai fait un batch pour concaténer des fichiers txt en 1 seul. Et j'en profite pour mettre dans le nom : la date et l'heure.

    Il marche bien MAIS il déraille pour les heures du matin entre 00h01 et 09H59.
    Il n'aime pas le 0 pour les dizaines d'heure.

    Voici mon code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    @echo off
    set mytime=%time:~0,2%%time:~3,2%%time:~6,2%
    copy /B c:\SQL\REP*.txt c:\ENVOI\BCREP01_%DATE:/=-%_%mytime%.txt
    Sur mon XP, il plante en disant (visible avec un PAUSE)
    le fichier obtenu est : BCREP01_13-05-2010_ 93356.txt
    (présence d'un espace avant 93356.txt)
    La syntaxe de la commande est incorrecte.
    Quelqu'un sait-il m'aider pour que l'heure soit toujours avec un 0 ou
    qu'il ne mette pas d'espace dans ce cas ?

    Merci

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Février 2008
    Messages
    252
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Février 2008
    Messages : 252
    Points : 124
    Points
    124
    Par défaut
    Salut,

    Je n'ai pas testé mais si tu ne veux pas d'espace essaye:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    copy /B c:\SQL\REP*.txt c:\ENVOI\BCREP01_%DATE:/=-%_%mytime: =%.txt
    Si tu veux un zéro à la place de l'espace:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    copy /B c:\SQL\REP*.txt c:\ENVOI\BCREP01_%DATE:/=-%_%mytime: =0%.txt
    Voila dis moi si ça marche ^^

    Bye

  3. #3
    Membre actif
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    683
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 683
    Points : 237
    Points
    237
    Par défaut
    Merci mais cela ne marche pas :
    la syntaxe est incorrect
    J'ai trouvé ce code sur le net (mais à force de recherche je ne sais plus si c'est ici ou ailleurs ?!)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    set heure=%time:~0,2%
    set min=%time:~3,2%
    set sec=%time:~6,2%
    :: On supprime l'espace avec l'option /a qui force une valeur numérique
    set /a heure_sans_espace=%heure%
    :: On ajoute un zéro
    set heure_avec_zero=0%heure_sans_espace%
    :: On ne conserve que les 2 dernier caractères
    set heure=%heure_avec_zero:~-2%
    @echo LE RESULTAT DONNE :
    @echo %heure%
    @echo %min%
    @echo %sec%
    set mytime=%heure%%min%%sec%
    Cela marche !

    MErci

  4. #4
    Membre averti

    Homme Profil pro
    Analyste d'exploitation
    Inscrit en
    Décembre 2003
    Messages
    333
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Analyste d'exploitation
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2003
    Messages : 333
    Points : 382
    Points
    382
    Billets dans le blog
    1
    Par défaut
    C'est pas compliquer, si tu donne 07 il le considère comme un décimal, 08 il le considère comme un octal. set /a est une vraie m... pour cela, c 'est lamentable de la part de ms...

    Utilise expr à la place, via unixutils

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

Discussions similaires

  1. Problème avec date et heure dans sql
    Par samibipbip dans le forum Langage SQL
    Réponses: 2
    Dernier message: 16/12/2011, 19h16
  2. [Dates] Problème avec date (heure qui varie)
    Par Death83 dans le forum Langage
    Réponses: 10
    Dernier message: 05/08/2006, 02h19
  3. requete avec date et heure
    Par robert_trudel dans le forum Access
    Réponses: 2
    Dernier message: 26/04/2006, 00h15
  4. Problème avec "Date()" en mode runtime
    Par bwalbourg dans le forum Runtime
    Réponses: 1
    Dernier message: 25/01/2006, 10h51
  5. [MySQL] Problème avec DATE SUB et INTERVAL
    Par psychoBob dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 25/01/2006, 00h36

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