发布于 2014-10-16 14:18:09 | 190 次阅读 | 评论: 0 | 来源: 网友投递

这里有新鲜出炉的Python入门,程序狗速度看过来!

Python编程语言

Python 是一种面向对象、解释型计算机程序设计语言,由Guido van Rossum于1989年底发明,第一个公开发行版发行于1991年。Python语法简洁而清晰,具有丰富和强大的类库。它常被昵称为胶水语言,它能够把用其他语言制作的各种模块(尤其是C/C++)很轻松地联结在一起。


本文为大家讲解的是Python原始字符串(raw strings)用法实例,在使用Python进行字符串处理的过程中非常具有实用价值,需要的朋友可以参考下

Python原始字符串的产生正是由于有正则表达式的存在。原因是ASCII 字符和正则表达式特殊字符间所产生的冲突。比如,特殊符号“b”在ASCII 字符中代表退格键,但同时“b”也是一个正则表达式的特殊符号,代表“匹配一个单词边界”。

为了让RE 编译器把两个字符“b”当成你想要表达的字符串,而不是一个退格键,你需要用另一个反斜线对它进行转义,即可以这样写:“\b”。

但这样做会把问题复杂化,特别是当你的正则表达式字符串里有很多特殊字符时,就更容易令人困惑了。一般来说,原始字符串经常被用于简化正则表达式的复杂程度。

事实上,很多Python 程序员在定义正则表达式时都只使用原始字符串。

下面的例子用来说明退格键“b” 和正则表达式“b”(包含或不包含原始字符串)之间的区别:

代码如下:
>>> m = re.match('bblow', 'blow') # backspace, no match #退格键,没有匹配>>> if m is not None: m.group()
...
>>> m = re.match('\bblow', 'blow') # escaped , now it works #用转义后,现在匹配了
>>> if m is not None: m.group()
...
'blow'
>>> m = re.match(r'bblow', 'blow') # use raw string instead #改用原始字符串>>> if m is not None: m.group()
...
'blow'


你可能注意到我们在正则表达式里使用“d”,没用原始字符串,也没出现什么问题。那是因为ASCII 里没有对应的特殊字符,所以正则表达式编译器能够知道你指的是一个十进制数字。

 

原始字符串的这个特性让一些工作变得非常的方便,比如正则表达式的创建。正则表达式是一些定义了高级搜索匹配方式的字符串,通常是由代表字符、分组、匹配信息、变量名和字符类等的特殊符号组成。正则表达式模块已经包含了足够用的符号。但当你必须插入额外的符号来使特殊字符表现的像普通字符的时候,你就陷入了“字符数字”的泥潭!这时原始字符串就会派上用场了。

除了原始字符串符号(引号前面的字母“r”)以外,原始字符串跟普通字符串有着几乎完全相同的语法。这个'r'可以是小写也可以是大写,唯一的要求是必须紧靠在第一个引号前。在3个例子的第1个例子里面,我们需要一个反斜杠加一个“n”来而不是一个换行符。

>>> 'n'
'n'
>>> print 'n'
>>> r'n'
'\n'
>>> print r'n'
n


接下来的例子里,我们打不开我们的README文件了,为什么?因为't'和'r'被当成不在我们的文件名中的特殊符号,但它们实际上是文件路径中的4个独立的字符。

 

>>> f = open('C:windowstempreadme.txt', 'r') Traceback (most recent call last):
File "", line 1, in ?
f = open('C:windowstempreadme.txt', 'r')IOError: [Errno 2] No such file or directory: 'C:\win- dows\tempreadme.txt'
>>> f = open(r'C:windowstempreadme.txt', 'r')>>> f.readline()
'Table of Contents (please check timestamps for last update!)n'
>>> f.close()

 



最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务