一、问题分析

使用split函数时出现了:ValueError: not enough values to unpack (expected 2, got 1)的问题,从英文的解析上来看,意思是没有足够的值去解压缩,期望是两个元素,但是只得到一个元素。
也就是说key1, key2 = line.split("->")这块,我只得到了一个值,所以我用两个返回值去取就会出错。
二、问题解决
代码如下:
def getOneDotFile(dotFile):
with open(dotFile, encoding="utf-8") as f:
while True:
line = f.readline()
if not line:
break
# 节点关系->:子->父
line = line.strip()
if line.find("->"):
# print(line)
key1, key2 = line.split("->")
child = key1.strip()
father = key2.strip().strip(";")
print(child)
print(father)
continue
这段代码里我从文件一行一行地读取数据,而数据里掺杂了不同的数据:
1->0;
sub
2->1;
sddd
我通过find函数来区分是否包含->来将它们区分,但是如果是sub这些字符,通过split就只能得到一个了,那么问题就出在于find,通过对find函数的深入解析,发现如果没找到元素是返回-1,所以问题很明显了,find("->") != -1才是真正的错误所在。
三、问题思考
其实找出问题所在并不像描述的那样简单,因为系统报错的位置在于split,那么我们就会纠结了split函数中,或者通过打印或者通过调试的方式才是解决方法的良好思路。在调试的时候我们就会在不属于我们需要匹配的位置进入if语句中,那么这时候我们就会发现该问题,最后找到find的问题所在,所以在发现问题时并非一味百度,而是自己先思考和调试后再寻求帮助,可能对自己提升会更大。
本文详细分析了一个Python编程中遇到的ValueError,该错误发生在尝试使用split函数拆分字符串时。作者通过逐步排查,发现问题源于对find函数的理解不准确,导致在未找到特定分隔符时仍尝试进行split操作。解决方案是加入条件判断,确保分隔符存在再执行split。此外,文章强调了解决问题时自我思考和调试的重要性,而非盲目依赖搜索引擎。
2万+

被折叠的 条评论
为什么被折叠?



