Python正则表达式如何删除代码行


Python正则表达式在Python语言中有很广泛的应用范围,我们不能更好的使用时因为没有了解到他的真谛。其实我们只有更好的学习才能不断的完善在今后的使用。

Python正则表达式Regular Expression,简称Regex),是指一个用来描述或者匹配一系列符合某个句法规则的字符串的单个字符串。正则表达式是一种处理文本的强大工具,删除代码行号对于它来讲是小菜一叠。代码如下:

  1. import re #导入Python的正则表达式模块  
  2. def CutLineNum (inStr):  
  3. multiStr = inStr.splitlines(1) outStr = u'' 
  4. p = re.compile(r'\D*\d+\s?[.|:|\]|\)]?\s?') #编译正则表达式   
  5. for singleLine in multiLine: outStr += p.sub( '', singleLine,
    count = 1 ) #用空字符替换每行的第一个匹配上述正则表达式的字符串   
  6. eturn outStr #返回累加后的字符串 

以上代码中的咖色部分就是一个Regex,它的含义是:0或多个非数字字符 + 至少1个数字字符 + 0或1个空白字符 + 0或1个分隔符(包括点、冒号、右圆/方括号,可添加其他分隔符) + 0或1个空白字符。

以上Regex符合大多数代码前行号的规则,删除行号就是用空字符替换掉每行代码中第一个匹配该Regex的字符串注意只能是第一个,因为程序里可能会存在abc1.open等情况,如果全部匹配就会误删代码)。

继续优化——采用函数编程

看起来还不够简洁,没关系,Python正则表达式是一种“准”函数编程Functional Programming,FP)语言,做这种简化代码的事情最拿手。在这里,我用到了两种函数编程手段——匿名函数lambda)和一种高阶函数map),将代码简化至一行,如下:
 

  1. import re #导入Python的正则表达式模块  
  2. outStr = ''.join(map(lambda x:re.compile(r'\D*\d+\s?[.
    |:|\]|\)]?\s?').sub( '', x,
    count = 1 ),inStr.splitlines(1)))) 

以上就是对Python正则表达式的详细介绍。这样代码就只优化到了一行了,是不是很简洁呢?当然代码的可读性受到一定影响。所以函数编程不能滥用。滥用的例子可以见我的文章《学习Python列表内涵:一行代码搞定双倍超立方数计算》)。函数编程是个稍微复杂点的问题,我觉得掌握与否均可,所以就不很详细地去解释上述代码了。

评论关闭