.读取一个文件所有内容,通过生成器调用一次获取一行数据.
#当前读取的行数n,记录从第几行开始读取,默认为0
#path读取文件的路径
def myread(path,n=0):
with open(path,mode=“r”,encoding=“utf-8”)as fp:
res = fp.readline()
n+=1
while res:
print("你当前读取的行数行数%s"%n)
yield res
res=fp.readline()
n+=1
path=“mytext.txt”
#获取生成器对象
mygen=myread(path)
#遍历生成器
for i in mygen:
print(i)
方法二:通过read读取字符数
#fpath 表示文章路径
def read_file(fpath):
with open(fpath,mode=“r”,encoding=“utf-8”)as fp:
read_length=60
while True:
res=fp.read(read_length)
if res:
yield res
else:
return
#读取一个长的字符串
s=""
import random
for i in range(random.randrange(1,10000)):
res=str(i)
s+=res
i=0
def mygen():
i=0
while 1:
res=s[i:i+10]
i+=50
if res:
yield res
else:
return
it=mygen()
#使用 try except打印,
try:
while 1:
print(next(it))
except:
print(“生成器调用完毕”)