2012-05-01 14 views
5

Tworzę mały program, który odczyta i wyświetli tekst z dokumentu. Mam plik testowy, który wygląda tak:Czy istnieje sposób, aby odczytać plik .txt i zapisać każdą linię w pamięci?

12,12,12 
12,31,12 
1,5,3 
... 

i tak dalej. Teraz chciałbym Python czytać każdą linię i zapisać go w pamięci, więc po wybraniu wyświetlania danych, wyświetli go w powłoce jako takie:

1. 12,12,12 
2. 12,31,12 
... 

i tak dalej. Jak mogę to zrobić?

+8

Pokaż nam swój kod tak daleko – Jordonias

+3

'pydoc file.readlines' – bjarneh

+1

@bjarneh readlines() nie jest pamięci skuteczny. –

Odpowiedz

13

znam go jest już odpowiedział :) Podsumowując powyższe:

# It is a good idea to store the filename into a variable. 
# The variable can later become a function argument when the 
# code is converted to a function body. 
filename = 'data.txt' 

# Using the newer with construct to close the file automatically. 
with open(filename) as f: 
    data = f.readlines() 

# Or using the older approach and closing the filea explicitly. 
# Here the data is re-read again, do not use both ;) 
f = open(filename) 
data = f.readlines() 
f.close() 


# The data is of the list type. The Python list type is actually 
# a dynamic array. The lines contain also the \n; hence the .rstrip() 
for n, line in enumerate(data, 1): 
    print '{:2}.'.format(n), line.rstrip() 

print '-----------------' 

# You can later iterate through the list for other purpose, for 
# example to read them via the csv.reader. 
import csv 

reader = csv.reader(data) 
for row in reader: 
    print row 

drukuje na mojej konsoli:

1. 12,12,12 
2. 12,31,12 
3. 1,5,3 
----------------- 
['12', '12', '12'] 
['12', '31', '12'] 
['1', '5', '3'] 
4

należy przechowywać je w tablicy

f = open("file.txt", "r") 
a = [] 
for line in f: 
    a.append(line) 
+0

bardzo prosty sposób robienia tego. !! – Surya

+5

Znany również jako "a = open (" file.txt "). Readlines()' lub bardziej równoważnie 'a = list (open (" file.txt "))'. Powinieneś naprawdę używać instrukcji 'with' do zamknięcia pliku; jest to zależne od semantyki ponownego liczenia CPython i nie będzie działać zgodnie z oczekiwaniami w ramach np. PyPy. – Dougal

+0

nie napotyka problemów, jeśli tekst jest bardzo duży z większą liczbą wierszy w pliku? – Surya

1

Możesz być także zainteresowany w module csv. To pozwala analizować, czytać i zapisywać pliki w wartości oddzielonych przecinkami (CSV) format ... co Twój przykład wydaje się być w

. Przykład:

import csv 
reader = csv.reader(open('file.txt', 'rb'), delimiter=',') 
#Iterate over each row 
for idx,row in enumerate(reader): 
    print "%s: %s"%(idx+1,row) 
0
with open('test.txt') as o: 
    for i,t in enumerate(o.readlines(), 1): 
     print ("%s. %s"% (i, t)) 
0
#!/usr/local/bin/python 

t=1 

with open('sample.txt') as inf: 
    for line in inf: 
     num = line.strip() # contains current line 
     if num: 
      fn = '%d.txt' %t # gives the name to files t= 1.txt,2.txt,3.txt ..... 
      print('%d.txt Files splitted' %t) 
      #fn = '%s.txt' %num 
      with open(fn, 'w') as outf: 
       outf.write('%s\n' %num) # writes current line in opened fn file 
       t=t+1 
1

Dzięki za doskonałe rozwiązanie @PePr. Ponadto możesz spróbować wydrukować plik .txt za pomocą wbudowanej metody String.join(data). Na przykład:

with open(filename) as f: 
    data = f.readlines() 
print(''.join(data)) 
Powiązane problemy