美文网首页
Python语言基础之——异常和正则

Python语言基础之——异常和正则

作者: D低调en | 来源:发表于2020-07-02 20:58 被阅读0次

    1.异常捕获

    1.什么是异常捕获:

    让程序执行过程中出现异常的时候不崩溃可以继续进行
    注意:不是任何时候都要只用异常捕获,是在你明明知道某个位置可能会出现异常,但是又不想让程序崩溃

    2.异常捕获的语法

    1)语法一:捕获所有异常
    try:
    代码段1
    except:
    代码段2
    说明:
    try、except - 关键字,固定写法
    : - 固定写法
    代码段1 - 和try保持一个缩进的一条或多条语句;可能会出现异常的代码(需要补货异常的代码)
    代码段2 - 出现的异常被捕获到了,需要执行的代码
    执行过程:先执行代码段1,如果执行过程中出现异常,直接执行代码段2,如果没有异常,代码段2就不会执行
    2)语法二:针对指定类型的异常进行捕获

    try:
    代码段1
    except 异常类型:
    代码段2
    执行过程:先执行代码段1,如果代码段1出现异常,判断出现的异常类型和except后面的异常类型是否一致,如果一致程序不崩溃直接执行代码段2,如果不一致,程序直接崩溃
    3)语法三:同时捕获多种异常做相同处理
    try:
    代码段1
    except (异常类型1,异常类型2...):
    代码段2
    4)语法四:同时捕获多种异常针对不同异常做不同的处理
    try:
    代码段1
    except 异常类型1:
    代码段11
    except 异常类型2:
    代码段22
    ...........

    3.finally关键字

    在所有异常捕获的语法结构后面都可以添加finally关键字:
    try:
    代码段1
    except:
    代码段2
    finally:
    代码段3
    无论前面出现什么情况,finally都会执行

    2.正则表达式

    re模块是Python提供的专门使用正则表达式的相关的函数模块
    from re import fullmatch,search
    1.什么是正则表达式:

    正则表达式是一种让字符串处理更简单的工具(本质是做字符串匹配)

    2.正则表达式的语法:

    fullmatch(正则表达式, 字符串) - 让正则表达式和字符串进行完全匹配,如果匹配失败结果是None

    import re
    # 匹配符号:
    
    # 1)普通字符 - 表示字符本身
    re_str = r'abc'
    result = fullmatch(re_str, 'abc')
    print(result)
    # 2) 特殊字符 .   -  匹配一个任意字符
    list1 = [1, 2]
    re_str = r'.abc.'
    result = fullmatch(re_str, '8abc0')
    print(result)
    # 3) \w  -  匹配任意一个数字、字母或者下划线(只针对ASCII表有效) 不好用!!
    re_str = r'\wabc'
    result = fullmatch(re_str, '3abc')
    print(result)
    # 4)\d - 匹配任意一个数字字符
    re_str = r'\d\d\d'
    result = fullmatch(re_str, '234')
    print(result)
    # 5)\s - 匹配一个空白字符 能产生空白字符: 空格 制表符 回车
    re_str = r'\s\d..'
    result = fullmatch(re_str, ' 4da')
    print(result)
    # 6)\D \S
    '''
    \字母 - 小写字母和对应的大写字母功能相反
    '''
    # 7)[字符集] - 匹配字符集中出现的任意一个字符
    '''
    注意:一个[]只能匹配一个字符
    a.
    [abc123] - 匹配a,b,c,1,2,3中任意一个字符
    b.
    [a-z] - 匹配字符a到字符z之间的任意一个字符
    [a-zA-Z] - 要求前面字符的编码值比后面的小
    [\u4e00-\u9fa5]
    '''
    re_str = r'[abc123]123'
    result = fullmatch(re_str, 'a123')
    # 判断输入的手机号码是否合法
    re_str = r'1[3-9]\d\d\d\d\d\d\d\d\d'
    result = fullmatch(re_str, '15100373890')
    print(result)
    
    re_str = r'[_a-zA-Z\d]abc'
    result = fullmatch(re_str, '_abc')
    print(result)
    # 8)[^字符集] - 取不在字符集中的任意一个字符
    print(fullmatch(r'[^abc]123', 'd123'))
    # 检测符号
    # 1)\b 检测是否是单词的边界
    '''
    单词边界:字符串开头、字符串结尾、凡是能区分出两个不同单词的符号都属于单词边界
    注意:检测类的符号不影响匹配的长度,只是在匹配成功的时候做进一步的检测
    '''
    message = 'how are you? i am fine! thank you'
    re_str = r'\d\d\s\b\d\d'
    print(fullmatch(re_str, '56 66'))
    # 2)^ 检测^所在的位置是否是字符串的开头
    re_str = r'\d\d\d'
    print(search(re_str, '543fafa456ddad'))
    # 3)$ - 检测$所在的位置是否是字符串结尾
    re_str = r'\d\d\d$'
    print(search(re_str, 'fafa424ddad543'))
    # 匹配次数
    # 1)* - 匹配0次或多次
    '''
    字符* - 字符出现0次或者多次
    '''
    re_str = r'abc\d*'
    print(fullmatch(re_str, 'abc235262456745'))
    # 2 + - 匹配一次或多次
    # 3 ? - 匹配0次或1次
    # 练习:写一个正则表达式,可以匹配任意整数字符串
    re_str = r'[-+]?\d*'
    print(fullmatch(re_str, '-32535'))
    # 4){}
    '''
    {N} - 匹配 N 次
    {M,N} - 匹配M到N次
    {M,} - 匹配至少M次
    {,N} - 匹配最多N次
    '''
    re_str = r'\d{4,9}'
    print(fullmatch(re_str, '3344435'))
    # 贪婪和非贪婪:
    '''
    在匹配次数不确定的情况下,匹配模式有两种:贪婪和非贪婪
    贪婪:默认都是贪婪的(在能匹配到的前提下,匹配次数尽可能多)
    非贪婪:在匹配次数不确定的时候,次数后面加?,匹配方式就是非贪婪的
    '''
    # 贪婪:能匹配到的前提下,匹配次数尽可能多
    re_str = r'\d{2,}'
    print(search(re_str, '护士34242您好!'))
    # 非贪婪:能匹配到的前提下,匹配次数尽可能少
    re_str = r'\d{2,}?'
    print(search(re_str, '护士34242您好!'))
    

    3.分支和分组

    from re import fullmatch
    # 1.分支 |
    # 正则1|正则2|正则3
    # 写一个正则匹配一个字符串:123abc 和 456abc
    re_str = r'123abc|456abc'
    print(fullmatch(re_str, '123abc'))
    # 2.分组()
    '''
    1)整体操作
    2)重复:
    \M - 重复前面第M个分组匹配到的内容,M从1开始
    3)捕获 findall
    4)转移符号:在具有特殊功能或者特殊意义的符号前加\,让功能消失
    '''
    # abc出现三次
    re_str = r'(abc){3}'
    print(fullmatch(re_str, 'abcabcabc'))
    re_str = r'(123|456)abc'
    print(fullmatch(re_str, '456abc'))
    # 两个数字两个字母的结构重复4次
    re_str = r'(\d\d[a-zA-Z][a-zA-Z]){4}'
    print(fullmatch(re_str, '45fa45fa45fa45fa'))
    
    re_str = r'(\d\d)=\1abc'
    print(fullmatch(re_str, '32=32abc'))
    # 注意:独立存在有特殊功能的符号在[]中功能会自动消失
    

    相关文章

      网友评论

          本文标题:Python语言基础之——异常和正则

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