笔记

作者: 微生活_小阿楠 | 来源:发表于2020-12-30 15:38 被阅读0次

    1.re.match必须从第一个字符开始匹配,如果第一个字符匹配不上,就返回none
    2.re.search是扫描整个字符串,返回第一个字符开始匹配,如果第一个字符匹配不上,就返回None(re.search比re.match好用多了)
    3.re.findall搜索字符串,以列表形式返回全部能匹配的子串
    4.re.sub替换已有字符串中每一个匹配的子串后,返回替换后的字符串
    (例子:import re
    5.re.compile将正则字符串编译成正则表达式对象(方便复用)

    content = 'Extra stings Hello 1234567 World_This is a Regex Demo Extra stings'

    正则表达式匹配到的字符串使用'replace'代替,返回替换后的字符串

    content = re.sub('\d+', 'replace', content)
    print(content)

    输出:Extra stings Hello replace World_This is a Regex Demo Extra stings)

    1.使用括号得到匹配目标
    2.尽量使用泛匹配(.
    3.尽量使用非贪婪模式(.
    ?)
    4.有换行符就用re.S


    2020-2-1 15:41

    一颗星()和两颗星(*)
    Python 函数支持默认参数和可变参数,一颗星表示不限数量的单值参数,两颗星表示不限数量的键值对参数
    Python 函数允许同时全部或部分使用固定参数、默认参数、单值(一颗星)可变参数、键值对(两颗星)可变参数,使用时必须按照前述顺序书写。

    def do_something(name, age, gender='男', *args, **kwds):
    print('姓名:%s,年龄:%d,性别:%s'%(name, age, gender))
    print(args)
    print(kwds)

    do_something('xufive', 50, '男', 175, 75, math=99, english=90)
    姓名:xufive,年龄:50,性别:男
    (175, 75)
    {'math': 99, 'english': 90}

    此外,一颗星和两颗星还可用于列表、元组、字典的解包,看起来更像C语言:

    a = (1,2,3)
    print(a)
    (1, 2, 3)
    print(a)
    1 2 3
    b = [1,2,3]
    print(b)
    [1, 2, 3]
    print(
    b)
    1 2 3
    c = {'name':'xufive', 'age':51}
    print(c)
    {'name': 'xufive', 'age': 51}
    print(c)
    name age
    print('name:{name}, age:{age}'.format(
    *c))
    name:xufive, age:51
    ————————————————
    版权声明:本文为CSDN博主「天元浪子」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/xufive/article/details/102856921

    yield以及生成器和迭代器

    迭代器--》可以像list那样被遍历,但又不占用多少内存(如,在py2时代,range()返回的是list,但如果range(10000000)的话,
    会消耗大量内存资源,所以,py2又搞了一个xrange()来解决这个问题。py3则保留了xrange(),但写作range()。xrange()返回的
    就是一个迭代器,它可以像list那样被遍历,但又不占多少内存。generator(生成器)是一种特殊的迭代器,只能被遍历一次
    ,遍历结束,就自动消失了。总之,不管是迭代器还是生成器,都是为了避免使用list,从而节省内存。)

    python内置了迭代函数iter,用于生成迭代器,用法如下:
    a = [1,2,3]
    a_iter = iter(a)
    for i in a_iter:
    print(i,end=', ')

    1,2,3,

    yield则是用于构造生成器的。比如,我们要写一个函数,返回从0到正整数的所有整数的平方,传统的代码写法是这样的:

    def get_square(n):
    result = list()
    for i in range(n):
    result.append(pow(i,2))
    return result

    print(get_square(5))
    [0,1,4,9,16]

    但是如果计算1亿以内的所有整数的平方,这个函数的内存开销会非常大,这时yield就可以大显身手了:

    def get_square(n):
    for i in range(n):
    yield(pow(i,2))

    a = get_square(5)
    for i in a:
    print(i,end=', ')

    0,1,4,9,16,
    如果再次遍历,则不会有输出了。

    装饰器-----》作用就是快速便捷的读出函数运行的时长

    如:
    import time
    def timer(func):
    def wrapper(args,kwds):
    t0 = time.time()
    func(
    args,**kwds)
    t1 = time.time()
    print('耗时%0.3f'%(t1-t0,))
    return wrapper

    @timer
    def do_something(delay):
    print('函数do_something开始')
    time.sleep(delay)
    print('函数do_something结束')

    do_something(3)
    函数do_something开始
    函数do_something结束
    耗时3.077

    timer()是我们定义的装饰器函数,使用@把它附加在如何一个函数(比如do_something)定义之前,就等于把
    新定义的函数,当成了装饰器函数的输入参数。运行do_something()函数,可以理解为执行了timer(do_something)。
    细节虽然复杂,不过这么理解不会偏差太大,且更易于把握装饰器的制造和使用。

    巧用断言assert
    所谓断言,就是声明表达式的布尔值必须为真的判定,否则将触发AssertionError异常。严格来讲,assert是调试手段,
    不宜使用在生产环境中,但这不影响我们用断言来实现一些特定功能,比如,输入参数的格式、类型验证等。

    def i_want_to_sleep(delay):
    assert(isinstance(delay, (int,float))), '函数参数必须为整数或浮点数'
    print('开始睡觉')
    time.sleep(delay)
    print('睡醒了')

    i_want_to_sleep(1.1)
    开始睡觉
    睡醒了
    i_want_to_sleep(2)
    开始睡觉
    睡醒了
    i_want_to_sleep('2')
    Traceback (most recent call last):
    File "<pyshell#247>", line 1, in <module>
    i_want_to_sleep('2')
    File "<pyshell#244>", line 2, in i_want_to_sleep
    assert(isinstance(delay, (int,float))), '函数参数必须为整数或浮点数'
    AssertionError: 函数参数必须为整数或浮点数


    相关文章

      网友评论

          本文标题:笔记

          本文链接:https://www.haomeiwen.com/subject/vruhoktx.html