ドキュメントからテキストを読み取って表示する小さなプログラムを作成しています。次のようなテストファイルがあります。
12,12,12
12,31,12
1,5,3
...
等々。ここで、Pythonに各行を読み取ってメモリに保存させたいので、データの表示を選択すると、シェルに次のように表示されます。
1. 12,12,12
2. 12,31,12
...
等々。これどうやってするの?
私はそれがすでに答えられていることを知っています:)上記を要約すると:
# 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
それは私のコンソールに印刷されます:
1. 12,12,12
2. 12,31,12
3. 1,5,3
-----------------
['12', '12', '12']
['12', '31', '12']
['1', '5', '3']
配列に格納してみてください
f = open( "file.txt", "r" )
a = []
for line in f:
a.append(line)
@PePrの優れたソリューションをありがとう。さらに、組み込みのメソッドを使用して.txtファイルを印刷してみることができますString.join(data)
。例えば:
with open(filename) as f:
data = f.readlines()
print(''.join(data))
csv
このモジュールにも興味があるかもしれません。これにより、コンマ区切り値(csv)形式でファイルを解析、読み取り、および書き込むことができます...これは、例のように見えます。
例:
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)
with open('test.txt') as o:
for i,t in enumerate(o.readlines(), 1):
print ("%s. %s"% (i, t))
#!/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