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
Ca veut dire que tu essaies d'appliquer la méthode split sur un tuple, alors qu'elle ne fonctionne pas pour ce type d'objet mais pour les string.
Pour info, les tuples sont, en gros, des listes immutables (qu'on ne peut pas modifier).
La question qui vient naturellement à l'esprit est la suivante :
Comment obtiens-tu ces tuples ?
(Un bout de code faciliterait grandement les réponses, à ce niveau).
Pourquoi la dernière ? Il n'y a pas de honte à poser des questions, qui plus est sur un forum d'entraide.
Hello
Alors si tu arrives a ouvrir ton fichier, je suppose que tu as fais les manip suivante:
Ouverture du fichier
Ici le 'r' sert a dire que tu es en mode 'Read' , c'est a dire lecture. Donc tu ne peux que LIRE ton fichier et en aucun cas écrire dedans
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2 MonFichier=open('le_nom_de_ton_fichier','r')
Pour écrire, il faut etre en mode 'w' (c'est a dire Write, donc écriture)
Extraction des lignes :
maintenant que tu as fais ca, ton fichier s'appelera MonFichier dans ton script.
Si tu veux lire ton fichier tu utilise la méthode readline(), ce qui donne:
Traitement de la ligne:
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2 line=MonFichier.readline()
Maintenant, la variable 'line' contiendra la premiere ligne de ton fichier sous forme de chaine de charactere.
tu peux t'amuser a faire
ce qui t'affichera dans ta console la premiere ligne.
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2print line
Maintenant si tu veux traiter ta ligne (comme tu dit, séparer en mot), il te faudra utiliser la méthode split qui permet de transformer une chaine de charactere en une liste et tu peux spécifier le séparateur (espace par défaut).
Ex de split:
Cecit dit, sache que quand tu utilise la méthode "readline()", la chaine de charactere retourné contient le saut de ligne (\n). Si tu veux traiter ta ligne sans le saut de ligne, il faut donc l'enlever:
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10 a='salut la compagnie' b=a.split() print b ['salut','la','compagnie'] a='1,2,3,nous irons aux bois' b=a.split(",") print b ['1','2','3','nous irons aux bois']
J'espere que tu as tout compris.
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3 line=line[:-1] #on recopie ici l'ensemble de la ligne en enlevant le dernier charactere (\n)
L'ensemble de ces trucs est trés trés bien expliqué dans le tuto de G SWINNEN qui est excellent pour apprendre, disponible (gratuitement) à cette adresse:
http://python.developpez.com/cours/apprendre-python3/
Et aussi les cours et tutoriels pour apprendre la programmation Python : http://python.developpez.com/cours/
Have fun!
merci beaucoup, j'ai très bien compris, c'est tout à fait clair.
Je m'y mets de suite pour essayer d'appliquer tous ces conseils.
Encore merci à tous!!
Alors pourquoi j'ai des tuples alors que j'ai toujours eu une chaine normale... CA JE NE SAIS PAS! Peut être que j'ouvre mal mes fichiers alors.
voilà :
monfichier1=open('objet.txt')
monfichier2=open('animaux.txt')
fichier=monfichier1.read()
fichier2=monfichier2.read()
liste=fichier.split(), fichier2.split()
Mais erreur!!!
Ou alors :
monfichier1=open('objet.txt')
monfichier2=open('animaux.txt')
fichier=monfichier1.read(), monfichier2.read()
liste=fichier.split()
Mais re-erreur!!
Voyez-vous le problème?
Bonsoir,
Ce n'est pas la ton problème.
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 Python 2.6.2 (release26-maint, Apr 19 2009, 01:56:41) [GCC 4.3.3] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> monfichier1=open('objet.txt') >>> monfichier2=open('animaux.txt') >>> fichier=monfichier1.read() >>> fichier2=monfichier2.read() >>> liste=fichier.split(), fichier2.split() >>> >>> liste (['tutu', 'tata', 'toto'], ['tortue', 'serpent', 'poison']) >>> >>> liste=fichier.split() + fichier2.split() >>> liste ['tutu', 'tata', 'toto', 'tortue', 'serpent', 'poison'] >>>
Pense à relire la doc.
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7 >>> fichier=monfichier1.read(), monfichier2.read() >>> type(fichier) <type 'tuple'> >>> liste=fichier.split() Traceback (most recent call last): File "<stdin>", line 1, in <module> AttributeError: 'tuple' object has no attribute 'split'
@+
ok j'ai réussi mais plus j'avance, plus les soucis arrivent!!!
Je veux que Python reconnaisse s'il s'agit d'un objet ou d'un animal quand je lui donne un mot.
Voilà mon problème:
liste = fichier1.read() + fichier2.read()
world = liste.split()
world = ([(name, 'objet') for name in world.words('objet.txt')] + [(name, 'animaux') for name in world.words('animaux.txt')])
random.shuffle(worlds)
L'erreur est 'list' object has no attribute 'words'!
Je continue de chercher mais si je pouvais avoir un coup de pouce...
merci
Pour le coup tu as une fois world et une fois wolrdS
Enfin je suis même pas sur que ce soit ton probleme. si j'ai bien compris ce que tu essaye de faire:
Tu as 2 fichiers
Objet
Animaux
Tu souhaite avoir une fonction qui charge les deux fichiers, puis est capable de dire si une entrée est de type Objet, Animaux ou ni l'un ni l'autre??
enfin j'ai peut-être rien compris a ton projet, mais si tu veux être aidée plus efficacement tu devrait peut etre d'abord:
1) expliquer clairement ton projet
2) Donner ton code (ou du moins des morceaux) à l'aide des balise CODE (le # situé au dessus de la zone de texte)
3) Lire le tuto de G Swinnen qui te donnera a peu prés tout ce que tu dois savoir pour lire un fichier, séparer en liste, gérer tes objets etc...
Parce que la on en est déja à deux pages pour un probleme de lecture de fichier et de découpage d'une chaine de charactere en liste... On va jamais s'en sortir!
ok, j'ai mis des bouts de code déjà mais c'est vrai pas au bon format! Dsl
Oui tu as tout à fait compris ce que je souhaitais faire avec Python!
Voilà, bon je vais chercher encore...
Merci a bientôt
Ok, bon faut pas le prendre mal. C'est juste des conseils pour avoir des réponse claires et rapides.
Alors je vais (encore) me répéter, mais vraiment le tuto que je t'ai conseillé est incontournable. C'est LA référence francophone et il y a tout ce qu'il faut pour débuter en python (jusqu'a un niveau relativement avancé même)
Pour ton probleme voila ce que tu dois faire
Tes morceaux de code semblent ok, mais uniquement parce que ton fichier ne contient qu'une seule ligne. Si tu t'amuse a mettre des nom sur plusieurs lignes, n'oublie pas de mettre une boucle while pour tout lire.
Maintenant, on reste dans l'optique une seule ligne, voici la strucuture que je te propose:
Voila, j'espere que ca t'aide dans ton probleme. Et tu peux voir ici, que si ta question est claire, la réponse l'est aussi en générale
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
35
36
37
38
39
40
41
42 #Cette fonction prend en entrée un mot. Si ce mot est présent dans le fichier #objet ou animaux, cela est écrit sur la console. De plus, il retourne une #chaine de caractere qui spécifie si il s'agit d'un objet, d'un animal #ou ni l'un ni l'autre, afin de pouvoir l'utiliser dans un programme plus complexe def Objet_ou_Animal(input) animaux=open('animaux.txt','r') objets=open('objet.txt','r') #On lit la premiere ligne de chacun des fichiers line_animaux=animaux.readline() line_objets=objets.readline() #supression du caratere "fin de ligne" (\n) line_animaux=line_animaux[:-1] line_objets=line_objet[:-1] #Transformation en liste: liste_animaux=line_animaux.split() liste_objet=line_objets.split() #On cherche si l'entrée de la fonction, cad la variable input est présente dans une des deux listes: if input in liste_animaux: print "C'est un animal" output='animal' elif input in liste_objet: print "C'est un objet" output='objet' else: print "Ni un objet, ni un animal" output='rien' return output #Main mot=raw_input('entrez votre mot') #L'utilisateur entre son mot Objet_ou_Animal(mot) # On appel la fonction écrite plus haut
Oui merci beaucoup d'avoir pris du temps pour m'expliquer.
Super!
Merci
Vous avez un bloqueur de publicités installé.
Le Club Developpez.com n'affiche que des publicités IT, discrètes et non intrusives.
Afin que nous puissions continuer à vous fournir gratuitement du contenu de qualité, merci de nous soutenir en désactivant votre bloqueur de publicités sur Developpez.com.
Partager