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

C# Discussion :

Mettre toutes les dates au format voulu, peu importe les paramètres régionaux des dates/heures ? [Débutant]


Sujet :

C#

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Avril 2013
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Avril 2013
    Messages : 31
    Points : 26
    Points
    26
    Par défaut Mettre toutes les dates au format voulu, peu importe les paramètres régionaux des dates/heures ?
    Bonjour,



    J'ai une question (bête) sur les formats de date/heure.

    Sur ce code très simple

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
                DateTime time = DateTime.Now;
                string format = "yyyy-MM-dd HH:mm:ss";
                label1.Text = DateTime.Now.ToString(format);

    Je peux facilement obtenir ce résultat

    2014-08-05 09:40:54

    Cependant, si le parametre régional de Windows (options régionales et linguistiques / heures HKEY_CURRENT_USER\Control Panel\International\sTime) contient un ".", je ne parviens pas à forcer le séparateur de l'heure avec le double point ":" car il me retourne toujours ce format

    2014-08-05 09.46.11


    Toutefois, si je désire un format de ce type (yyyy-MM-dd HH|mm|ss)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
                DateTime time = DateTime.Now;
                string format = "yyyy-MM-dd HH|mm|ss";
                textBox1.Text = DateTime.Now.ToString(format);
    le résultat est, et reste toujours...

    2014-08-05 09|51|39
    ...et ce, que le paramètre régional soit un ":" ou un "."



    Pourquoi donc n'est il pas possible de forcer le ":" ?



    Espérant avoir été assez explicite


    D'avance, merci

  2. #2
    Membre actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2010
    Messages
    119
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2010
    Messages : 119
    Points : 202
    Points
    202
    Par défaut
    Bonjour,

    Le séparateur par défaut ":" est dépendant des paramètres régionaux il pourra donc être remplacé en fonction de ces paramètres. Tu peux forcer le fait de ne pas prendre en compte les paramètre régionaux en utilisant la propriété
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CultureInfo.InvariantCulture
    ce qui donnera :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DateTime.Now.ToString("MM/dd/yyyy HH:mm:ss", CultureInfo.InvariantCulture)
    Darkcrift

  3. #3
    Expert confirmé
    Avatar de Pragmateek
    Homme Profil pro
    Formateur expert .Net/C#
    Inscrit en
    Mars 2006
    Messages
    2 635
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Formateur expert .Net/C#
    Secteur : Conseil

    Informations forums :
    Inscription : Mars 2006
    Messages : 2 635
    Points : 4 062
    Points
    4 062
    Par défaut
    Il me semble que tu dois aussi pouvoir échapper ":" :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    string format = "yyyy-MM-dd HH\\:mm\\:ss";
    Formateur expert .Net/C#/WPF/EF Certifié MCP disponible sur Paris, province et pays limitrophes (enseignement en français uniquement).
    Mon blog : pragmateek.com

  4. #4
    Membre actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2010
    Messages
    119
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2010
    Messages : 119
    Points : 202
    Points
    202
    Par défaut
    Il faut savoir qu'en fonction des régions du mondes ou l'appli sera déployée le type de calendrier(grégorien ou autre) peut ne pas être le même dans les paramètres régionaux.
    Cela peut poser des problèmes en fonction de l'utilisation et des traitements que tu fais sur la date.
    Définir le "CultureInfo.InvariantCulture" garantie une unicité du format de la date quelque soit les paramètre régionaux par défaut.

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Avril 2013
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Avril 2013
    Messages : 31
    Points : 26
    Points
    26
    Par défaut
    Formidable !

    Merci darkcrift (et Pragmateek pour s'être intéressé au souci ) pour cet éclaircissement je ne comprenais pas trop le fonctionnement de CultureInfo.

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 10/08/2008, 13h52
  2. mettre une date en format dd/mm/year en paramètre d'une fonction
    Par friedamichelle dans le forum Général Java
    Réponses: 2
    Dernier message: 03/03/2008, 19h09
  3. Réponses: 11
    Dernier message: 12/09/2007, 16h58
  4. [Oracle] traitement des dates au format string
    Par shaftJackson dans le forum Langage SQL
    Réponses: 2
    Dernier message: 29/01/2007, 19h25
  5. [Date] Comparer des dates au format mySQL "date
    Par Marc_P dans le forum Collection et Stream
    Réponses: 3
    Dernier message: 25/10/2004, 16h15

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