首页 > 代码库 > enumerate指定行号
enumerate指定行号
有时在对文件进行处理时会出现错误,文件比较小还好,但如果文件比较大,查找起来就比较麻烦,那要怎么获取出错
的行号呢?
这里用到了enumerate,通过enumerate来指定索引:
#!/usr/bin/env python #coding:utf-8 #@Author:Andy #Date: 2017/6/18 def parse_data(file_name): with open(file_name, ‘rt‘) as f: for line_no , line in enumerate(f, 1): fields = line.split() try: count = int(fields[0]) except ValueError as e: print("line {} :parse error: {}".format(line_no, e)) if __name__ == ‘__main__‘: parse_data(‘parse_data.txt‘)
parse_data.txt文件内容如下:
当出错时,先打印行号,再输出错误信息:
这 里的enumerate可以通过第二个参数指定初始值,根据人的使用情况,这里指定为1:,默认情况
下为0
但是要注意,对于元组,在利用enumerate时,并不能自动对其进行解包,而是报错:
data = http://www.mamicode.com/[ (1, 2), (3, 4), (5, 6), (7, 8) ]>
解包:报错
for x, y, z in enumerate(data): print(x, y, z) Traceback (most recent call last): File "C:\Program Files\Python35\lib\site-packages\IPython\core\interactiveshell.py", line 2869, in run_code exec(code_obj, self.user_global_ns, self.user_ns) File "<ipython-input-11-138a8a540361>", line 1, in <module> for x, y, z in enumerate(data): ValueError: not enough values to unpack (expected 3, got 2)
enumerate指定行号
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。