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

Bibliothèques tierces Python Discussion :

openpyxl formatage en type date d'une colonne d'un tableau


Sujet :

Bibliothèques tierces Python

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2023
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Septembre 2023
    Messages : 1
    Points : 1
    Points
    1
    Par défaut openpyxl formatage en type date d'une colonne d'un tableau
    Bonjour,

    Dans un traitement Python de données, je dois restituer les données dans une feuille excel.
    Pour cela j'utilise le package openpyxl.

    J'ai créé un tableau et y ai chargé les données depuis un Dataframe pandas.

    Les colonnes contenant des dates sont au format Datetime dans le Dataframe.
    Dans le tableau Excel, je souhaite avoir uniquement les dates en format "Date Courte".

    J'ai trouvé pour formater une cellule, mais j'aimerai pouvoir formater un ensemble de colonnes ("J" à "AP") et là cela coince, j'ai besoin d'aide.

    Merci pour votre aide.

    Le code relatif à l'écriture dans un fichier Excel :

    from openpyxl import Workbook
    from openpyxl.worksheet.table import Table, TableStyleInfo
    from openpyxl.utils import get_column_letter
    from openpyxl.utils.dataframe import dataframe_to_rows
    from openpyxl.worksheet.dimensions import ColumnDimension, DimensionHolder
    from openpyxl.styles import numbers

    wb = Workbook()
    ws = wb.active # Prendre la feuille Active
    ws.title = "Table LTP" # définir le nom de la feuille


    for r in dataframe_to_rows(LTP, index=False, header=True):
    ws.append(r)

    NomTableau = "DonnéesLTP"
    RefTableau = 'A1:%s%d' % (get_column_letter(len(LTP.columns)), len(LTP.index) + 1) # Ajouter 1 pour le nombre de lignes car inclu la ligne d'Entête

    StyleTableau = TableStyleInfo(name="TableStyleMedium15", showFirstColumn=False,
    showLastColumn=False, showRowStripes=True, showColumnStripes=False)

    Tableau = Table(displayName=NomTableau, ref=RefTableau)

    Tableau.tableStyleInfo = StyleTableau

    ws.add_table(Tableau)


    # Dimensionnment des Colonnes
    for col in range(ws.min_column, ws.max_column + 1):
    ws.column_dimensions[get_column_letter(col)].width = 12

    ws.column_dimensions["B"].width = 50
    ws.column_dimensions["C"].width = 50
    ws.column_dimensions["D"].width = 25
    ws.column_dimensions["E"].width = 15
    ws.column_dimensions["G"].width = 25
    ws.column_dimensions["H"].width = 20


    # Formatage des colonnes Date
    # Sur une cellule pas de problème pour "2013-04-01 0:00:00" dans le Dataframe j'obtiens bien "1/4/13" dans le tableau Excel
    ws["J7"].number_format = numbers.FORMAT_DATE_DMYSLASH

    # Sur une colonne ça coince
    ws["J"].number_format = numbers.FORMAT_DATE_DMYSLASH # Problème ????

    # Et je souaite formater les colonne de "J" à "AP"
    ws["J:AP"].number_format = numbers.FORMAT_DATE_DMYSLASH # Problème ????

  2. #2
    Rédacteur/Modérateur

    Avatar de User
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    8 264
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2004
    Messages : 8 264
    Points : 19 432
    Points
    19 432
    Billets dans le blog
    63
    Par défaut
    Bonsoir,

    Vous n'avez pas moyen de travailler sur un modèle xlsx avec des cellules déjà formatées que vous copiez dans le dossier de votre choix avant de le mettre à jour avec vos données ?

    Cdlt
    Vous trouverez dans la FAQ, les sources ou les tutoriels, de l'information accessible au plus grand nombre, plein de bonnes choses à consulter sans modération

    Des tutoriels pour apprendre à créer des formulaires de planning dans vos applications Access :
    Gestion sur un planning des présences et des absences des employés
    Gestion des rendez-vous sur un calendrier mensuel


    Importer un fichier JSON dans une base de données Access :
    Import Fichier JSON

Discussions similaires

  1. Réponses: 1
    Dernier message: 22/01/2019, 12h48
  2. Recherche sur date avec une colonne de type varchar
    Par Cladjidane dans le forum Requêtes
    Réponses: 3
    Dernier message: 21/08/2008, 22h35
  3. Reformatage de 2 types de dates dans une colonne
    Par jeo13 dans le forum Macros et VBA Excel
    Réponses: 18
    Dernier message: 25/03/2008, 08h32
  4. formatage date d'une colonne DataTable
    Par mappy dans le forum VB.NET
    Réponses: 4
    Dernier message: 14/09/2007, 11h35
  5. DBGrid: formatage de l'affichage d'une colonne
    Par SAca dans le forum Bases de données
    Réponses: 6
    Dernier message: 14/05/2004, 17h33

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