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

Python Discussion :

Conversion de date Julien à date calendrier


Sujet :

Python

  1. #1
    Membre régulier
    Homme Profil pro
    Consultant MOA
    Inscrit en
    Août 2017
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Consultant MOA

    Informations forums :
    Inscription : Août 2017
    Messages : 8
    Par défaut Conversion de date Julien à date calendrier
    Bonjour,

    J'ai une liste des dates en format Julien [737456, 737457, 737458, 737459, ...] qui débute de 01/01/00.

    Je connais la manip sous R :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    > as.Date(737456,origin="00-01-01")
    [1] "2019-02-01"
    Je n'arrive pas à trouver ou implémenter une fonction équivalente sous Python.

    Quelqu'un a une idée de comment faire cela svp?

    Merci

  2. #2
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 828
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 828
    Billets dans le blog
    1
    Par défaut
    Bonjour

    J'ai trouvé cette discussion qui donne une formule et qui en parle.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  3. #3
    Membre régulier
    Homme Profil pro
    Consultant MOA
    Inscrit en
    Août 2017
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Consultant MOA

    Informations forums :
    Inscription : Août 2017
    Messages : 8
    Par défaut
    Ça ne résout pas mon problème. :/ En fait le résultat dépend de la date origine prise :

    1) 2440224 correspond à 02/01/1969 dans la discussion que tu m'as forwardée

    2) en utilisant datetime de python

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    import datetime
    datetime.datetime.fromtimestamp(2440224)
    Je trouve 29/01/1970

    3) En utilisant la commande R as.Date() avec la même date origine qui correspond à celle de mes données

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     as.Date(2440224, origin = '00-01-01')
    Je trouve 08/02/6681.

    C'est pour cela je cherche une façon sous python de fixer la date d'origine pour correspondre à celle de mes données.

  4. #4
    Membre régulier
    Homme Profil pro
    Consultant MOA
    Inscrit en
    Août 2017
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Consultant MOA

    Informations forums :
    Inscription : Août 2017
    Messages : 8
    Par défaut
    Une solution que j'ai trouvé est datetime.fromordinal().
    la date d'origine de datetime.fromordinal() est le 01/01/0001

    Donc
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    datetime.datetime.fromordinal(myJulianDate-365)
    correspond à la format que je cherche (date d'origine 01/01/0000)

  5. #5
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 828
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 828
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Khaled_MI70 Voir le message
    Ça ne résout pas mon problème. :/ En fait le résultat dépend de la date origine prise :

    1) 2440224 correspond à 02/01/1969 dans la discussion que tu m'as forwardée

    2) en utilisant datetime de python

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    import datetime
    datetime.datetime.fromtimestamp(2440224)
    Je trouve 29/01/1970

    3) En utilisant la commande R as.Date() avec la même date origine qui correspond à celle de mes données

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     as.Date(2440224, origin = '00-01-01')
    Je trouve 08/02/6681.
    Ben oui. Ca dépend surtout de la façon dont la fonction gère les dates et surtout dont elle gère le nombre que tu lui donnes.
    Python (tout comme Unix) les gère en secondes. Et 2440224 secondes correspondent à 28,24 jours qui, s'ils commencent au timestamp d'Unix (1/1/70) donnent alors la date du 29/01/70. Si "R" gère différemment il est normal que la date finale ne soit pas la même.

    Etant donné que je ne suis pas certain que les programmeurs des librairies Python aient pensé à gérer le calendrier Julien, j'espérais te faire trouver une formule de translation.

    Citation Envoyé par Khaled_MI70 Voir le message
    Une solution que j'ai trouvé est datetime.fromordinal().
    la date d'origine de datetime.fromordinal() est le 01/01/0001

    Donc
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    datetime.datetime.fromordinal(myJulianDate-365)
    correspond à la format que je cherche (date d'origine 01/01/0000)
    Ok, si ça marche c'est le principal
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

Discussions similaires

  1. Conversion date calendrier républicain
    Par p1xl_01 dans le forum Collection et Stream
    Réponses: 4
    Dernier message: 12/07/2011, 09h52
  2. oracle conversion de date et jour julien
    Par corwin dans le forum JDBC
    Réponses: 5
    Dernier message: 23/05/2008, 13h12
  3. - [CAST ou CONVERT] Problème de conversion de date
    Par Boublou dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 06/07/2004, 14h31
  4. Conversion de date lors d'un import
    Par bilbon.S dans le forum SQL Procédural
    Réponses: 4
    Dernier message: 26/03/2004, 14h33
  5. Conversion de date et division 64 bits
    Par dway dans le forum Assembleur
    Réponses: 38
    Dernier message: 27/01/2004, 10h31

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