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 :

Fonction - Mettre un DataFrame dans un fichier Excel existant


Sujet :

Python

  1. #1
    Membre averti
    Homme Profil pro
    Bidouilleur
    Inscrit en
    Février 2016
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Bidouilleur

    Informations forums :
    Inscription : Février 2016
    Messages : 20
    Par défaut Fonction - Mettre un DataFrame dans un fichier Excel existant
    Bonjour,

    J'ai fait une fonction qui me permet d'ajouter des données depuis un DataFrame à un fichier Excel.

    - Lors du premier lancement, le fichier est créé et j'applique une couleur sur la première colonne.
    - Le deuxième lancement est ok.
    - Lors du troisième lancement, je perds la mise en forme (la couleur dans ce cas) sur les lignes précédentes (3 et 4).

    Après le deuxième lancement, si j'ouvre le fichier (avec LibreOffice) et que je sauve, cela fonctionne correctement.
    Avez-vous une idée qui me permettrait d'éviter cette manipulation ?

    Merci

    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
    import pandas as pd
    import numpy as np
     
     
    def ajoute_dataframe_a_xlsx(fichier, dataframe):
        """
        Fonction qui permet d'ajouter un DataFrame dans un fichier Excel existant ou de le créer.
        Le DataFrame est ajouté à la suite dans la page active.
        S'il y a eu des mises en forme (taille des colonnes, en gras...), elles seront conservées.
     
        :param fichier: Nom du fichier Excel
        :param dataframe: Nom du DataFrame à enregistrer dans le classeur
        """
        from openpyxl import load_workbook
        dataframe_dans_liste = dataframe.values.tolist()    # Mettre le DataFrame dans une liste de liste
        try:    # Test que le fichier existe
            classeur = load_workbook(fichier)   # Charger le fichier xlxs
        except FileNotFoundError:   # Si le fichier n'existe pas, il est créé.
            from openpyxl.workbook import Workbook
            classeur = Workbook()
        page = classeur.active
        for info in dataframe_dans_liste:
            page.append(info)
     
        classeur.save(filename=fichier)
     
     
    # Pour teste
    colonne = ['col 1', 'col 2', 'col 3']
    ligne = [['test 1', 'test 2', 'test 3'], ['test 1', 'test 2', 'test 3']]
    df = pd.DataFrame(data=np.array(ligne), columns=colonne)
     
     
    ajoute_dataframe_a_xlsx('Test_fonction.xlsx', df)

  2. #2
    Membre averti
    Homme Profil pro
    Bidouilleur
    Inscrit en
    Février 2016
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Bidouilleur

    Informations forums :
    Inscription : Février 2016
    Messages : 20
    Par défaut
    Bonjour,

    J'ai trouvé une "solution"...
    Ça fonctionne, mais j'imagine qu'il y a beaucoup mieux.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    import pyautogui    # Control clavier souris
    import time
    import os
     
     
    scalc = r'%PROGRAMFILES%\LibreOffice\program\scalc.exe'     # Chemin de l'application LibreOffice Calc
    os.system("start scalc.exe --nologo Test_fonction.xlsx")    # On lance le fichier xlsx
    time.sleep(2)
    pyautogui.hotkey('ctrl', 's')   # Sauver le fichier
    time.sleep(1)
    pyautogui.hotkey('ctrl', 'q')   # Quitter

  3. #3
    Membre Expert
    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    1 536
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 1 536
    Par défaut
    et en ajoutant un classeur.close() après le save() si tu n'as pas besoin de le garder ouvert ?

  4. #4
    Membre averti
    Homme Profil pro
    Bidouilleur
    Inscrit en
    Février 2016
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Bidouilleur

    Informations forums :
    Inscription : Février 2016
    Messages : 20
    Par défaut
    Merci pour ta réponse, ça ne change rien.

    D'après ce que j'ai compris de la doc la méthode .close() est nécessaire uniquement en lecture.

Discussions similaires

  1. Réponses: 0
    Dernier message: 07/10/2009, 14h03
  2. Ecrire dans un fichier Excel existant
    Par Javix dans le forum Ruby
    Réponses: 6
    Dernier message: 21/02/2008, 21h47
  3. Réponses: 1
    Dernier message: 09/05/2007, 23h10
  4. [Excel] Écrire dans un fichier Excel existant
    Par Invité dans le forum Bibliothèques et frameworks
    Réponses: 5
    Dernier message: 01/05/2006, 16h06
  5. Mettre des donnees dans un fichier Excel
    Par Mouawad dans le forum C++Builder
    Réponses: 6
    Dernier message: 07/10/2004, 14h55

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