小小问题
import osos.chdir("D:\\编程\\编程文件垃圾库")
def fun(a):
global count
global listnew
if a == 0:
for each in listnew:
for eeach in each:
if eeach == temp1:
count += 1
return count
elif a == 1:
for each in listnew:
for eeach in each:
if eeach == temp1:
b = listnew.index(eeach)
listnew.remove(eeach)
listnew.insert(b, temp2)
return listnew
count = 0
list1 = []
name = input("请输入文件名:")
file = open(name)
for each_line in file:
list1.append(each_line)
listnew = list(map(str, list1))
print(listnew)
temp1 = input("请输入需替换的字符串:")
temp2 = input("请输入新的字符串:")
print("文件%s共有%d个%s" % (name, fun(0) , temp1))
juezi = input("你确定要替换所有的字符吗【yes/no】:")
if juezi == 'yes':
fun(1)
print(''.join(listnew))
print(listnew)
else:
print("好的")
帮找一下问题在哪里?T_T
根据你的描述,你的程序意图是读取一个文件,并且查询一个字符串在文件中出现的次数,如果用户选择,将会把这个字符串替换为另一个字符串。
问题出在这一段代码:
elif a == 1:
for each in listnew:
for eeach in each:
if eeach == temp1:
b = listnew.index(eeach)
listnew.remove(eeach)
listnew.insert(b, temp2)
return listnew
你尝试通过 listnew.index(eeach) 找到 eeach 的位置,然后删除和替换。但是这里有两个问题:
1.eeach 是 each (一个字符串)的每一个字符,你需要在字符串列表中寻找与 temp1 相等的字符串,而不是字符。
2. 当你删除一个元素后,列表的长度会改变,这会影响你的循环和插入元素的位置。
你可能想要这样做:
elif a == 1:
for idx, each in enumerate(listnew):
if each.strip() == temp1:
listnew = temp2
return listnew
enumerate 函数可以同时返回元素和它的索引,我们只需在找到相应字符串时替换它就可以了。
此外,为了处理文件,你可能需要在使用 open 后加上 close 来关闭文件,或者使用 with 语句,它可以帮助你自动管理文件的打开和关闭。此外,为了读取文件中的所有行,可以使用 file.readlines() ,这将返回一个包含每一行的列表。
希望这个解答能帮助到你! 脚本真好玩 over
页:
[1]