文件
魚友悶為甚麼count出來的數值是1..def my_file(file, replace_str, change_str):
file_read = open(file, encoding = 'utf-8')
data = []
my_count = 0
for eachline in file_read:
ifreplace_str in eachline:
my_count = eachline.count(replace_str)
eachline = eachline.replace(replace_str, change_str)
data.append(eachline) #把修改後的字串丟到串列裡
answer = input("裡面有%s個%s,確認需要修改?yes or no:" %(my_count, replace_str))
if answer == 'yes':
file_write = open("D://new_file_0520.txt", 'w')
file_write.writelines(data)
file_write.close()
file_read.close()
file = input("輸入文件名")
replace_str = input("輸入要替換的字符")
change_str = input("輸入要更新的字符")
my_file(file, replace_str, change_str)
跑出這個錯誤...
Traceback (most recent call last):
File "c:\Users\蔡承諺\OneDrive\文件\File_20200130\text.py", line 21, in <module>
my_file(file, replace_str, change_str)
File "c:\Users\蔡承諺\OneDrive\文件\File_20200130\text.py", line 14, in my_file
file_write.writelines(data)
UnicodeEncodeError: 'cp950' codec can't encode character '\u5416' in position 21: illegal multibyte sequence 本帖最后由 Twilight6 于 2020-5-20 16:41 编辑
编码问题
def my_file(file, replace_str, change_str):
file_read = open(file, encoding = 'utf-8')
data = []
my_count = 0
for eachline in file_read:
ifreplace_str in eachline:
my_count = eachline.count(replace_str)
eachline = eachline.replace(replace_str, change_str)
data.append(eachline) #把修改後的字串丟到串列裡
answer = input("裡面有%s個%s,確認需要修改?yes or no:" %(my_count, replace_str))
if answer == 'yes':
file_write = open("D://new_file_0520.txt", 'w',encoding='utf-8')
file_write.writelines(data)
file_write.close()
file_read.close()
file = input("輸入文件名")
replace_str = input("輸入要替換的字符")
change_str = input("輸入要更新的字符")
my_file(file, replace_str, change_str)
这样试试?
或者:
def my_file(file, replace_str, change_str):
file_read = open(file)
data = []
my_count = 0
for eachline in file_read:
ifreplace_str in eachline:
my_count = eachline.count(replace_str)
eachline = eachline.replace(replace_str, change_str)
data.append(eachline) #把修改後的字串丟到串列裡
answer = input("裡面有%s個%s,確認需要修改?yes or no:" %(my_count, replace_str))
if answer == 'yes':
file_write = open("D://new_file_0520.txt", 'w')
file_write.writelines(data)
file_write.close()
file_read.close()
file = input("輸入文件名")
replace_str = input("輸入要替換的字符")
change_str = input("輸入要更新的字符")
my_file(file, replace_str, change_str) 去掉encoding='utf-8' 本帖最后由 TsaiYen 于 2020-5-20 16:51 编辑
编码问题影响了
my_count输出的值吗 TsaiYen 发表于 2020-5-20 16:49
编码问题影响了
my_count输出的值吗
不是的 是因为报错是解码不了的原因才报错的
TsaiYen 发表于 2020-5-20 16:49
编码问题影响了
my_count输出的值吗
如果对你有帮助记得设置最佳哈~{:10_287:} Twilight6 发表于 2020-5-20 16:37
编码问题
这样试试?
恭喜你,再次误人子弟一次{:10_277:}
仔细看报错!是13行没加 encoding 的原因!
应该改成
def my_file(file, replace_str, change_str):
file_read = open(file, encoding = 'utf-8')
data = []
my_count = 0
for eachline in file_read:
ifreplace_str in eachline:
my_count = eachline.count(replace_str)
eachline = eachline.replace(replace_str, change_str)
data.append(eachline) #把修改後的字串丟到串列裡
answer = input("裡面有%s個%s,確認需要修改?yes or no:" %(my_count, replace_str))
if answer == 'yes':
file_write = open("D://new_file_0520.txt", 'w', encoding='utf-8')
file_write.writelines(data)
file_write.close()
file_read.close()
file = input("輸入文件名")
replace_str = input("輸入要替換的字符")
change_str = input("輸入要更新的字符")
my_file(file, replace_str, change_str) 永恒的蓝色梦想 发表于 2020-5-20 18:26
恭喜你,再次误人子弟一次
仔细看报错!是13行没加 encoding 的原因!
我写了两个代码~你看清楚哈哈哈哈{:10_277:} Twilight6 发表于 2020-5-20 18:34
我写了两个代码~你看清楚哈哈哈哈
{:10_306:}还有这种操作{:10_306:}
我谢罪{:10_245:} Twilight6 发表于 2020-5-20 18:34
我写了两个代码~你看清楚哈哈哈哈
谢啦~{:10_281:} 感谢鱼友的协助,太感谢了! TsaiYen 发表于 2020-5-20 18:52
感谢鱼友的协助,太感谢了!
嘿嘿~如果对你有帮助就给个最佳吧~{:10_288:} 永恒的蓝色梦想 发表于 2020-5-20 18:50
谢啦~
{:10_246:}荣誉 拿去 Pia!(o ‵-′)ノ”(ノ﹏<。)哈哈哈哈 Twilight6 发表于 2020-5-20 18:56
荣誉 拿去 Pia!(o ‵-′)ノ”(ノ﹏
为什么你评分次数那么多{:10_277:}…… 永恒的蓝色梦想 发表于 2020-5-20 19:09
为什么你评分次数那么多……
好像 上限一天是 8
页:
[1]