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 573
    D�tails du profil
    Informations personnelles :
    �ge : 46
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 1 573
    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