===========Python文件基础=========
写,先写在了IO buffer了,所以要及时保存 关闭。关闭会自动保存。
file.close()
读取全部文件内容用read,读取一行用readline—>string(如果是循环,下次读取下一行),读取多行readlines—>list(也是全部读完)
========Python文件的格式化写入=======
am001=open('Amfomat.txt','w')
s='%10s%10s%10s\n'%('Id','Name','Record')
am001.write(s)
s1='%10d%10s%10.2f\n'%(854179353,'amily',99.8)
am001.write(s1)
s2='%10d%10s%10.2f\n'%(347634734,'yiggle',98.8)
am001.write(s2)
s3='%10d%10s%10.2f\n'%(347634734,'yiggle',98.8)
am001.write(s3)
s4='%10d%10s%10.2f\n'%(347634734,'yiggle',98.8)
am001.write(s4)
s5='%10d%10s%10.2f\n'%(347634734,'yiggle',98.8)
am001.write(s5)
s6='%10d%10s%10.2f\n'%(347634734,'yiggle',98.8)
am001.write(s6)
am001.close()
============循环体和文件=======
>>> help(file.readline)
readline(...)
readline([size]) -> next line from the
file, as a string.
Retain newline. A non-negative size argument limits the
maximum
number of bytes to return (an incomplete
line may be returned then).
Return an empty string at EOF.
在linux下退出python环境 可以用quit()
>>> id1=open('Amfomat.txt','r')
>>> print id1.readline().strip('\n')
Id Name
Record
>>> print id1.readline().strip('\n') #第二次调用就自动取了下一行
854179353 amily
99.80
>>> print id1.readline().strip('\n')
347634734 yiggle
98.80
===============用while和readline循环输出文件中所有内容=========
fw=open('Amfomat.txt','r')
s=fw.readline()
while s!='':
s=s.rstrip('\n')
print s
s=fw.readline()
fw.close()
==================for和file_obj=======================
fr=open('Amfomat.txt','r')
for str in fr:
str=str.strip('\n')
print str
fr.close()
这跟上面的遍历输出文件内容效果是一样的。
s=’www.baidu.com’
for str1 in s:
print str1,
结果为 w w w . b a
i d u . c o m
>>> s='www.baidu.com'
>>> si=iter(s) #iter(xxx),获取xxx的迭代器,str和list以及tuple都可以用迭代器,因此也都可以用for语句
>>> si.next()
是从第一个开始的
'w'
>>> si.next()
'w'
>>> si.next()
'w'
>>> si.next()
'.'
i = iter('abcd')
print i.next()
print i.next()
print i.next()
s = {'one':1,'two':2,'three':3}
print s
m = iter(s)
print m.next()
print m.next()
print m.next()
结果
a
b
c
{'three': 3, 'two': 2, 'one': 1}
three
two
one
只要某一个对象是一个有序的聚合对象,就可以通过迭代器依次取出它的每个元素,因此也都可以用for语句,字符串,列表,元组,字典都是可以的。到最后一个值得时候抛出异常:stopiteration
for是通过获取对象的迭代器,然后在通过迭代器里的next方法依次取出迭代器里的各个元素。
对于文件 ,文件中的每一行就是这个文件局和对象的元素。
fr=open(‘for.py’,’r’)
fi=iter(fr)
print fi.next()
print fi.next()
print fi.next()
type(fr)--àfile