Bonjour à tous,
je voudrais savoir comment importer deux fichiers .txt dans Python afin de travailler dessus???
Cela doit être:
import nomdufichier1, nomdufichier2
mais je reçois toujours des erreurs...
Merci à tous pour votre aide!!![]()
Bonjour à tous,
je voudrais savoir comment importer deux fichiers .txt dans Python afin de travailler dessus???
Cela doit être:
import nomdufichier1, nomdufichier2
mais je reçois toujours des erreurs...
Merci à tous pour votre aide!!![]()
Bonjour,
Tu ne peux importer que des fichiers d'extension .py (modules) et an aucun cas des fichiers.txt.
Mais voici comment travailler sur ce genre de fichier:
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4 obFichier = open('Monfichier','a') obFichier.write('Bonjour, fichier !') obFichier.write("Quel beau temps, aujourd'hui !") obFichier.close()
ah mince je ne savais pas! ça va être donc beaucoup plus compliqué pour travailler sur ces deux fichiers...
Merci pour cette mauvaise nouvelle!!!
Bonsoir,
Jamais entendu parler d'import de fichier.
Par contre pour travailler sur un fichier il faut l'ouvrir, soit en mode lecture 'r' soit en mode écriture 'w', avec la fonction constitutive (= built-in) open. Note qu'il existe d'autres modes.
Il y a d'autres fonctions fopen, popen , popen2, popen3, popen4 dans le module os qui ouvrent des fichiers mais il vaut mieux les oublier car , bien qu'encore disponibles dans 2.6, elles y sont dépréciées : la doc conseille d'utiliser la fonction sophistiquée Popen du module subprocess, qui les remplace.
Il y a aussi la fonction tmpfile dans le module os, qui permet d'ouvrir un fichier en mode de mise à jour ('w+b') mais je ne l'ai jamais utilisé et je ne sais pas trop à quoi il peut servir d'ouvrir un fichier temporaire avec elle.
Il faut noter enfin l'existence de la fonctionnalité mmap, que j'ai vu signalée dans ce forum par wiztricks et qui est très intéressante.
La classe mmap du module mmap (mmap.mmap) est un constructeur d'objet-fichier particulier, dit "memory-mapped".
Un memory-mapped objet-fichier se comporte à la fois
- comme un objet-fichier habituel (tel que crée par open):
on peut y utiliser seek, tell,etc
- et comme une chaîne:
on peut y faire des désignation de caractère et du slicing au moyen d'indices.
On peut aussi y utiliser les expressions régulières, sans avoir à charger le contenu du fichier dans une chaîne par ch = f.read()
- mais CERISE SUR LE GÂTEAU, il s'agit d'une nature de chaîne particulière puisque, contrairement aux objets chaîne habituels, un mmap objet-fichier est mutable.
On peut donc utiliser les indices et le slicing pour modifier un ou plusieurs caractères de façon plus simple qu'avec un objet-fichier habituel.
Je n'ai pas encoe utilisé cette fonctionnalité, mais à mon avis elle doit être super pratique.
http://docs.python.org/library/mmap.html#mmap.mmap
mmmm un peu compliqué sachant que je débute juste!!! Merci quand même...
travailler avec c'est à dire faire des manipulations sur ces textes!
Voilà je sais que je dois mettre mes fichiers dans le même répertoire que mon script Python.
Est-ce que quelqu'un sait ce que cela signifie??
Merci beaucoup pour votre aide...
Si je comprends bien, tu veux dans un script Python avoir le contenu texte d'un fichier. Si cela que tu veux, il suffit de faire comme suit.
monFichier.txt
Le script suivant placé dans le même dossier te permet de lire ton fichier ligne par ligne :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4 Ligne n°1 Ligne n°2 Ligne n°3 Ligne n°4
Tu obtiendras dans la console :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6 #!/usr/bin/env python #coding=utf-8 with open('monFichier.txt', 'r') as myFile: for oneLine in myFile.readlines(): print(oneLine)
Il n'y a aucune obligation d'avoir le fichier à traiter et le script dans le même dossier.Ligne n°1
Ligne n°2
Ligne n°3
Ligne n°4
Il suffira de remplacer 'monFichier.txt' par le chemin complet du fichier à traiter.
Salut !
Effectivement, tu ne peux importer que des modules Python (et pas uniquement que des fichiers .py, mais on fera comme si pour l'instant).
Pour ton besoin tel que je l'ai compris, la dernière contribution de rambc me semble être la meilleure, à la seule correction que je ferais plutôt :
j'évite de faire un appel à la méthode readlines car elle génère une liste contenant toutes les lignes du fichiers, ce qui peut s'avérer pénalisant si le fichier est important.
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5 # Syntaxe Python2.6, je ne garantis pas pour les autres versions. with open('myfile.txt') as myfile: for line in file: #Pas de readlines print line
Pour ce qui est du nom de ton fichier à passer en argument de la fonction open, sache qu'il peut s'agir indifféremment du chemin relatif ou du chemin absolu du fichier.
Enfin, veille bien à préciser ton problème au maximum.
Quand tu parles de manipulations sur les textes, je vois plusieurs cas:
1. Tu dois juste comparer les 2 fichiers => utilisation d'open, voire du module filecomp si tu dois juste savoir si les 2 fichiers sont identiques ou pas ;
2. Tu dois modifier un fichier en fonction du 2° => mmap, comme indiqué par eyquem semble parfait pour ça, et je jeterais un oeil sur fileinput aussi (haha, un module a échappé à l'oeil de lynx d'eyquem) ;
3. Tu dois ajouter à la fin du 1° fichier les lignes contenant un nombre pair de caractères du 2° fichier => re-utilisation d'open, avec le mode 'a' (comme append) ;
4. Tu dois copier l'intégralité du 1° fichier dans le 2° fichier => module shutil ;
5. Tes fichiers sont en fait des fichiers CSV => module csv (le bien-nommé) ;
6. Tes fichiers contiennent des caractères accentués => module codecs ou module io (pas saisi la différence entre les 2).
Comme tu vois, au + tu précises ton problème, aux mieux seront les réponses.
Il arrive même qu'on trouve tout seul la réponse en essayant de préciser son problème.![]()
Oui merci beaucoup!!!
J'ai enfin réussi à ouvrir mes fichiers... Grace à vous!
Mais est-ce que quelqu'un sait ce que signifie le message d'erreur 'tuple' object has no attribute 'split'?
Je veux couper mon texte en mots mais pourquoi je n'y parviens pas?
Ca sera ma dernière question... J'espère!
merci
Tu ne devrais pas. Mon avis sur le mot reference est idiot.même si je comprends ton avis
Il doit y avoir des tas de gens qui utilisent Python pour faire de la gestion de stock; on ne va pas leur dire de proscrire le mot reference comme nom de ... référence. Parce que si ce n’est pas un mot réservé, ce n’est pas pour rien: il n’y a aucune conséquence fâcheuse à utiliser ce mot, je n’en vois aucune. Je me range à ton avis.
Même si on n’utilise pas de list comprehension, il n’y a pas création de liste:Terrible, l'utilisation de la compréhension de liste pour NE PAS construire de liste.
La forme list comprehension est utilisée ici pour faire une action, tandis qu’habituellement la list comprension construit une liste c’est vrai.
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3 d = {} for (nomdefichier, categorie) in [('animaux.txt','animal'),('objets.txt', 'objet')]: d.update( (mot,categorie) for mot in open(nomdefichier).readline().split() )
renvoie None, qui s’évapore dans la mémoire vive.
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2 [ d.update( (mot,categorie) for mot in open(nomdefichier).readline().split() ) for (nomdefichier, categorie) in [('animaux.txt','animal'),('objets.txt', 'objet')] ]
Il reste le dictionnaire qui a été modifié par les instructions internes.
Partager