davidmou 发表于 2023-7-19 00:09:18

小小问题

import os
os.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

isdkz 发表于 2023-7-19 00:10:26

根据你的描述,你的程序意图是读取一个文件,并且查询一个字符串在文件中出现的次数,如果用户选择,将会把这个字符串替换为另一个字符串。

问题出在这一段代码:
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() ,这将返回一个包含每一行的列表。

希望这个解答能帮助到你!

sfqxx 发表于 2023-7-19 00:36:37

脚本真好玩

davidmou 发表于 2023-7-19 10:52:17

over
页: [1]
查看完整版本: 小小问题