re.sub(pattern, repl, string, count=0, flags=0)
其中三个必选参数:pattern, repl, string
两个可选参数:count, flags
第一个参数:pattern
pattern,表示正则中的模式字符串。
需要知道的是:
反斜杠加数字(\N),则对应着匹配的组(matched group)
比如\6,表示匹配前面pattern中的第6个group
意味着,pattern中,前面肯定是存在对应的,第6个group,然后你后面也才能去引用。
第二个参数:repl
repl,就是replacement,被替换为的字符串的意思。
repl可以是字符串,也可以是函数。
如果repl是字符串的话,其中的任何反斜杠转义字符,都会被处理的。
即:
\n:会被处理为对应的换行符;
\r:会被处理为回车符;
其他不能识别的转移字符,则只是被识别为普通的字符:
比如\j,会被处理为j这个字母本身;
反斜杠加g以及中括号内一个名字,即:\g,对应着命了名的组,named group
第三个参数:string
string,即表示要被处理,要被替换的那个string字符串。
没什么特殊要说明。
第四个参数:count
对于匹配到的内容,只处理其中一部分。
re.subn(pattern, repl, string[, count=0])
与sub()相同, 但返回一个元组, 其中包含新字符串和替换次数。
random.sample(sequence, k)
从指定序列sequence中随机获取指定长度k的片断,不会修改原有序列。
import random
list = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
slice = random.sample(list, 5) # 从list中随机获取5个元素,作为一个片断返回
print slice
print list # 原有序列并没有改变
结果:
[5, 10, 4, 1, 2]
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]