这篇文章给大家分享的是有关python怎么删除文本中行数标签的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
Python的优点有哪些
1、简单易用,与C/C++、Java、C# 等传统语言相比,Python对代码格式的要求没有那么严格;2、Python属于开源的,所有人都可以看到源代码,并且可以被移植在许多平台上使用;3、Python面向对象,能够支持面向过程编程,也支持面向对象编程;4、Python是一种解释性语言,Python写的程序不需要编译成二进制代码,可以直接从源代码运行程序;5、Python功能强大,拥有的模块众多,基本能够实现所有的常见功能。
问题描述:
我们在网上下载或者复制别人代码的时候经常会遇到下载的代码中包含行数标签的情况。如下图:
这些代码中包含着行数如1.,2.等,如果我们想直接运行或者copy代码需要自己手动的删除这些标签。既然学了python,我们写一段脚本来处理它吧。
思路分析:
首先,我们逐行的读取文本。
利用正则表达式,可以顺利地匹配出所有的这些标签以及后面跟随的“\t”,正则表达式为:“\d+.\t”。
接着我们将匹配的结果在这一行中删除它,使用string模块的replace方法,将匹配的结果用‘'代替。
最后,我们保存每次删除了行数标签的结果行,然后将这些行写入原文本。注意,以w的方式打开文本会删除原文本内容。
代码:
# -*- coding:utf-8 -*-
import re
import os
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
ls = os.linesep
label_regex = r'\d+.\t'
content = []
for line in open('source.txt', 'r'):
mm = re.search(label_regex, line)
if mm:
mm = mm.group()
content.append(line.replace(mm, '').rstrip())
else:
break
f = open('source.txt', 'w')
f.writelines(['%s%s' % (x,ls) for x in content])
结果:
感谢各位的阅读!关于“python怎么删除文本中行数标签”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!