os模块
import osdef out(f_name):
posi=[]
f=open(f_name,encoding='utf-8')
f.seek(0,2)
n=f.tell()
f.seek(0,0)
i=0
while(f.tell() != n):
text=f.readline()
i+=1
ends=len(text)
num=0
if ('小甲鱼' not in text):
continue
else:
num=text.count('小甲鱼')
starts=0
while num>0:
k=text.find('小甲鱼',starts,ends)
posi.append(k)
num-=1
starts=k+3
print('在文件【】中找到关键字【小甲鱼】')
print('关键字出现在第%d行'%i,posi,'个位置')
print('============================================')
posi.clear()
f.close()
def search_file(start_dir) :
os.chdir(start_dir)
for each_file in os.listdir(os.curdir) :
if ('txt' in each_file) :
f_name=(os.getcwd() + os.sep + each_file) # 使用os.sep是程序更标准
out(f_name)
if os.path.isdir(each_file) :
search_file(each_file) # 递归调用
os.chdir(os.pardir) # 递归调用后切记返回上一层目录
start_dir = os.curdir
target=input('请将该脚本放于待查找的文件夹内,请输入关键字')
choose=input('请问是否需要打印关键字【%s】在文件中的具体位置(yes/no):'%target)
if choose=='yes':
search_file(start_dir)
else:
print('再见^_^')
所以这个情况程序到底成功没,问题又出在哪???一脸懵逼
有非UTF-8文件 把 encoding='utf-8' 去掉试试 永恒的蓝色梦想 发表于 2020-5-3 20:18
有非UTF-8文件
呃,那就是把所有的文件打开的encoding全加个utf-8吗,utf-8是什么意义???求大佬解惑 zltzlt 发表于 2020-5-3 20:20
把 encoding='utf-8' 去掉试试
ok,我试试 zltzlt 发表于 2020-5-3 20:20
把 encoding='utf-8' 去掉试试
不行,一删就报错 君子好逑 发表于 2020-5-3 20:24
不行,一删就报错
你的文件编码不一致,有的是 GBK 或其他的,有的是 UTF-8 zltzlt 发表于 2020-5-3 20:26
你的文件编码不一致,有的是 GBK 或其他的,有的是 UTF-8
这样的吗,有点难受
君子好逑 发表于 2020-5-3 20:21
呃,那就是把所有的文件打开的encoding全加个utf-8吗,utf-8是什么意义???求大佬解惑
非UTF-8文件加UTF-8干嘛?人类迷惑行为? zltzlt 发表于 2020-5-3 20:26
你的文件编码不一致,有的是 GBK 或其他的,有的是 UTF-8
谢谢大佬 永恒的蓝色梦想 发表于 2020-5-3 20:27
非UTF-8文件加UTF-8干嘛?人类迷惑行为?
{:10_250:} 永恒的蓝色梦想 发表于 2020-5-3 20:27
非UTF-8文件加UTF-8干嘛?人类迷惑行为?
呃,不加就直接报错 永恒的蓝色梦想 发表于 2020-5-3 20:27
非UTF-8文件加UTF-8干嘛?人类迷惑行为?
不加跟我上回报的错一样,上回有个大佬让我加上程序好了,所以这回我就加上了 君子好逑 发表于 2020-5-3 20:31
呃,不加就直接报错
因为什么文件编码都有 君子好逑 发表于 2020-5-3 20:32
不加跟我上回报的错一样,上回有个大佬让我加上程序好了,所以这回我就加上了
try except 捕获异常 永恒的蓝色梦想 发表于 2020-5-3 20:33
try except 捕获异常
那是不是意味着我只把用一种编码方式的文件放到文件夹里然后运行程序就ok了{:10_257:} 君子好逑 发表于 2020-5-3 20:39
那是不是意味着我只把用一种编码方式的文件放到文件夹里然后运行程序就ok了
是的 永恒的蓝色梦想 发表于 2020-5-3 20:39
是的
谢谢大佬指点
页:
[1]