关于提取文本中某些字符的问题,求帮忙,谢谢
关于提取文本中某些字符的问题,求帮忙,谢谢path = './log.txt'
#log.txt'的内容格式如下:
#mood_l1,2023-04-01 22:21:59
#mood_a1,2023-04-01 22:21:59
#需提取:['mood_l1','mood_a1']
ww = []
with open(path, "r", encoding='UTF-8') as f:
t = f.readlines()
txt = t.split(',')
ww.append(txt)
print(ww)
#出现错误提示:AttributeError: 'list' object has no attribute 'split' 你在处理文件中的每一行时出现了一个错误。readlines() 函数返回一个列表,列表中的每个元素都是文件中的一行。
你应该遍历这个列表,然后在每一行上调用 split() 函数。另外,你需要修复缩进。这里是修复后的代码:
path = './log.txt'
ww = []
with open(path, "r", encoding='UTF-8') as f:
lines = f.readlines()
for line in lines:
txt = line.split(',')
ww.append(txt)
print(ww)
这个修复后的代码应该可以正确地从文件中提取出所需的字符串列表:['mood_l1','mood_a1']。 问题在于你试图对一个列表对象进行 split() 操作,但是 split() 是一个字符串对象的方法。因此,你应该对列表中的字符串逐个进行 split() 操作,示例如下:
path = './log.txt'
#log.txt'的内容格式如下:
#mood_l1,2023-04-01 22:21:59
#mood_a1,2023-04-01 22:21:59
#需提取:['mood_l1','mood_a1']
ww = []
with open(path, "r", encoding='UTF-8') as f:
t = f.readlines()
for line in t:
txt = line.strip().split(',')
ww.append(txt)
print(ww)
在这个示例中,我用 for 循环逐行读取文件中的内容,然后对每一行进行 strip() 和 split() 操作,将结果添加到 ww 列表中。这样就可以得到你想要的结果了。同时注意要使用 strip() 方法剔除每行末尾的换行符,以及应该在循环内声明 txt 变量,因为每次循环都需要一个新的 txt 变量来保存当前行的结果。 isdkz 发表于 2023-4-11 22:00
你在处理文件中的每一行时出现了一个错误。readlines() 函数返回一个列表,列表中的每个元素都是文件中的一 ...
我趣我们的chatgpt给出的代码完全一样
页:
[1]