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 :

bonne pratique en python pour des manips sur une table SQL avec une scip orienté objet


Sujet :

Python

  1. #1
    Membre averti
    Femme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Juin 2022
    Messages
    36
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information

    Informations forums :
    Inscription : Juin 2022
    Messages : 36
    Par défaut bonne pratique en python pour des manips sur une table SQL avec une scip orienté objet
    Bonjour
    Je recois régulièrements des fichiers csv à analyser

    csv de meme format à chaque fois je précise, seule le contenu change.

    j'aimerai faire un script python qui me :
    - créé un table
    - charge les données de certaines colonnes dans la table (toujours les memes colonnes)
    - quelques analyses genre nombre de lignes du tableau, moyenne d'une colonne

    je pourrais faire un script linéaire.
    Mais j'aimerai m'entrainer à la POO.

    Je vais définir une classe qui contiendra alors les fonctions définies plus haut:

    ensuiet j'instancie la classe et j'appelle les fonctions de la classe pur faire les actions demandées

    Est-ce quelquechose de classique ou je me prends trop la tete?

  2. #2
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 811
    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 811
    Billets dans le blog
    1
    Par défaut
    Bonjour

    Déjà pourquoi créer la table à chaque fois ?

    Tu veux faire une table (donc une bdd) autant faire un truc un peu classe. Tu fais une table qui contient la référence du CSV, la date à laquelle tu l'as reçu, puis deux ou trois autres trucs. Et une seconde table dédiée à contenir les datas (reliée donc à la première). Ainsi tu auras les dernières données mais aussi les précédentes et tu pourras faire des recherches historiques. Dans une bdd normalisée 3FN.

    Puis tu crées ton objet bdd qui se charge de la connexion et des insert. Et ton objet csv qui, lui, se charge de récupérer les infos et les stocker dans la table. Là ça commence à avoir un peu de style...
    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 averti
    Femme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Juin 2022
    Messages
    36
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information

    Informations forums :
    Inscription : Juin 2022
    Messages : 36
    Par défaut
    je crée une nouvelle table à chaque fois car j'utilise sqlite.

    SI j'utilais postgre, je suis d'accord que je peux créer la table une seule fois.

    du coup avec sqlite, ma méthode est propre ou toujours pas?

  4. #4
    Expert confirmé
    Avatar de fred1599
    Homme Profil pro
    Lead Dev Python
    Inscrit en
    Juillet 2006
    Messages
    4 044
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Lead Dev Python
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4 044
    Par défaut
    Citation Envoyé par sqlbeginner Voir le message
    je crée une nouvelle table à chaque fois car j'utilise sqlite.


    sqlite ou postgresql, c'est du SQL, et par définition avec SQL, on peut vérifier si la table existe ou pas.

  5. #5
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 811
    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 811
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par fred1599 Voir le message
    Je crois que ce qu'il veut dire, c'est qu'il crée la base (le fichier sqlite) à chaque fois. Enfin j'imagine que c'est ça

    Citation Envoyé par sqlbeginner Voir le message
    SI j'utilais postgre, je suis d'accord que je peux créer la table une seule fois.
    Avec sqlite aussi (à condition que tu n'effaces pas le fichier ".db" à chaque coup).

    Citation Envoyé par sqlbeginner Voir le message
    du coup avec sqlite, ma méthode est propre ou toujours pas?
    Je n'ai pas dit qu'elle n'était pas propre. Le principal c'est de se faire plaisir avant tout donc si tu as envie de faire de l'objet fais de l'objet. Après effectivement si tes objets sont bien séparés ce sera évidemment plus propre que si tu bennes tout dans un gros bouzin à la c... (mais on avait le même problème en C quand il fallait décider si on créait un seul et unique gros main() ou un un petit main() et plein de fonctions associées).
    En fait, si tu es venu demander notre bénédiction, de mon point de vue tu l'as entièrement. Donc un objet bdd qui commence par créer la table et un objet csv qui lit le csv et qui charge la table (enfin c'est ce que je ferais). Et l'objet bdd peut détecter si la table existe déjà (ouverture d'un ancien sqlite) ou pas (création d'un neuf).
    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]

  6. #6
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 683
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 683
    Par défaut
    Salut,

    Citation Envoyé par sqlbeginner Voir le message
    Est-ce quelquechose de classique ou je me prends trop la tete?
    Le dernier O de POO est pour "objet".
    La question est de savoir de quel(s) objet(s) on parle et quelles méthodes, on va bien pouvoir lui(leur) appliquer (pour changer leur état).
    Dit autrement, avant de programmer des objets, il faut les concevoir... et imaginer à quoi il vont bien pouvoir servir.
    note: Un fichier CSV peut se représenter par un objet mais on a déjà file, csv.reader,... chaque ligne peut être objet mais on a déjà namedtuple, dataclass,...

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  7. #7
    Expert confirmé Avatar de papajoker
    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2013
    Messages
    2 292
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nièvre (Bourgogne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2013
    Messages : 2 292
    Par défaut
    bonjour
    Citation Envoyé par sqlbeginner Voir le message
    - créé un table
    - charge les données de certaines colonnes dans la table (toujours les memes colonnes)
    - quelques analyses genre nombre de lignes du tableau, moyenne d'une colonne

    Je vais définir une classe qui contiendra alors les fonctions définies plus haut:
    Créer une seule classe (fourre-tout) ce n'est en aucun cas de la poo. Au mieux c'est une perte de temps.

    Une classe ne fait qu'une chose (a minimum, nous dire quelles classes tu désires créer)
    Sans héritage, l'intérêt est plus que limité. Peut-être créer une classe générique "analyse" puis des dérivées ?

    ps: oui, pas compris pourquoi récréer la table si c'est sqlite ...

  8. #8
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 683
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 683
    Par défaut
    Citation Envoyé par papajoker Voir le message
    Créer une seule classe (fourre-tout) ce n'est en aucun cas de la poo. Au mieux c'est une perte de temps.
    Une seule classe permet juste de se passer du mot clef "global" mais si on ne l'instancie qu'une seule fois, çà n'apporte pas grand chose à l'objet module et ses objets fonctions. Dit autrement, comme avec Python tout est objet, inutile de dégainer "class" pour faire de la POO.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

Discussions similaires

  1. Besoin d'aide pour des combinaisons sur Python
    Par AntonT dans le forum Général Python
    Réponses: 10
    Dernier message: 05/11/2022, 16h19
  2. Recherche une solution pour des cours sur une VM
    Par Antoun dans le forum Virtualisation
    Réponses: 2
    Dernier message: 26/03/2022, 19h18
  3. Question sur la bonne pratique en programmation pour les boucles
    Par pierre-y dans le forum Langages de programmation
    Réponses: 7
    Dernier message: 05/09/2016, 07h05
  4. faire des requetes sur la table attributaire avec sql
    Par darkaminoo dans le forum SIG : Système d'information Géographique
    Réponses: 3
    Dernier message: 13/12/2010, 18h29
  5. Connectivité pour délimiter des formes sur une photo
    Par romu37fr dans le forum C++Builder
    Réponses: 2
    Dernier message: 27/06/2007, 13h28

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