Python中通过re模块实现了正则表达式的功能。re模块提供了一些根据正则表达式进行查找、替换、分隔字符串的函数。本文主要介绍正则表达式先关内容以及re模块中常用的函数和函数常用场景。

正则表达式基本语法

正则表达式就是使用预先定义好的特定字符以及这些特定字符的组成字符串的匹配表达式,然后利用表达式去匹配或提取字符串。因此,我们首先需要熟悉正则表达式中的特定字符以及它们的含义、用法。下面总体介绍一下正则表达式的基本元字符使用(源自百度百科 正则表达式

元字符使用基本实例

(1). 点号,表示匹配除换行"\n"外的任意1个字符。假设表达式:a.c,则匹配abc/a1c,不匹配ac。但是在python的re模块函数可以通过设置re.S标志让它也匹配换行符。

  1. >>> import re
  2. >>> re.findall(r'a.c','abc')
  3. ['abc']
  4. >>> re.findall(r'a.c','ac')
  5. []
  6. >>> re.findall(r'a.c','a\nc',re.S)
  7. ['a\nc']

(2)\ 转义字符,使后一个字符改变原来的含义。假设表达式为a\.c,则仅匹配a.c,不匹配abc、a1c等a与c之间非点号"."的字符串。在转义符"\"之后点号".失去了原来代表任意字符的含义。

  1. >>> re.findall(r'a\.c','a.c')
  2. ['a.c']
  3. >>> re.findall(r'a\.c','abc')
  4. []

(3)[...] 字符集,对应的位置可以是字符集中任意字符,字符集中的字符可以逐个列出,也可以给出范围,或者如果第1个字符是^表示取反。下面针对这几种情形逐一描述。

场景1:[...]字符集中的字符逐个列出。如[bcd]。假设正则表达式为a[bcd]e,则匹配abe、ade,但不匹配afe。实例如下:

  1. >>> re.findall(r'a[bcd]e','abe')
  2. ['abe']
  3. >>> re.findall(r'a[bcd]e','ade')
  4. ['ade']
  5. >>> re.findall(r'a[bcd]e','afe')
  6. []

场景2:[...]字符集中的字符以范围给出。假设表达式为a[a-d]e,相当于a[abcd]e。则匹配abe、ade。

  1. >>> re.findall(r'a[a-d]e','abe')
  2. ['abe']
  3. >>> re.findall(r'a[a-d]e','ade')
  4. ['ade']

场景3:如果[...]字符集第一个字符是^,则表示取反。假设表达式为a[^abc]e,则匹配afe,不匹配abe、ace。

  1. >>> re.findall(r'a[^abc]e','abe') # ^在中括号内表示取反的意思。所以a[^abc]e可以匹配afe、a1e,但不匹配abe、ace
  2. []
  3. >>> re.findall(r'a[^abc]e','afe')
  4. ['afe']

那如果^字符不是在第一个字符呢,那它就仅仅表示一个普通的字符。假设表达式为a[a^bc]e,则匹配abe、a^e、ace,不匹配afe。

  1. >>> re.findall(r'a[a^bc]e','abe')
  2. ['abe']
  3. >>> re.findall(r'a[a^bc]e','a^e')
  4. ['a^e']
  5. >>> re.findall(r'a[a^bc]e','afe')
  6. []

场景4:特殊字符在字符集[...]中都失去其原有的特殊含义。假设表达式为a[a.bc]e,则匹配abe、ace、a.e,不匹配afe

  1. >>> re.findall(r'a[a.bc]e','a.e') #特殊符号"."在中括号内失去了原有的含义。
  2. ['a.e']
  3. >>> re.findall(r'a[a.bc]e','afe')
  4. []

预定义字符集

(1)\d 表示1个数字,相当于[0-9]。假设表达式为a\dc,则匹配a1c,不匹配abc

  1. >>> re.findall(r'a\dc','a1c')
  2. ['a1c']
  3. >>> re.findall(r'a\dc','abc')
  4. []

(2)\D 表示1个非数字,相当于[^0-9]。假设表达式a\Dc,则匹配abc,不匹配a1c

  1. >>> re.findall(r'a\dc','a1c')
  2. ['a1c']
  3. >>> re.findall(r'a\dc','abc')
  4. []

(3)\s 表示1个空白字符,相当于[<空格>\t\r\n\f\v]。假设表达式为a\sc,则匹配a c,不匹配abc

  1. >>> re.findall(r'a\sc','a c')
  2. ['a c']
  3. >>> re.findall(r'a\sc','abc')
  4. []

(4)\S 表示1个非空白字符,相当于[^\s]。假设表达式为a\Sc,则匹配abc,不匹配a c

  1. >>> re.findall(r'a\Sc','abc')
  2. ['abc']
  3. >>> re.findall(r'a\Sc','a c')
  4. []

(5)\w 表示1个单词字符,相当于[a-zA-z0-9_]。假设表达式为a\wc,则匹配abc,不匹配a c

  1. >>> re.findall(r'a\wc','abc')
  2. ['abc']
  3. >>> re.findall(r'a\wc','a1c')
  4. ['a1c']
  5. >>> re.findall(r'a\wc','a c')
  6. []

(6)\W 表示1个非单词字符,相当于[^\w]。假设表达式为a\Wc,则匹配a c,不匹配abc

  1. >>> re.findall(r'a\Wc','a c')
  2. ['a c']
  3. >>> re.findall(r'a\Wc','a!c')
  4. ['a!c']
  5. >>> re.findall(r'a\Wc','a.c')
  6. ['a.c']
  7. >>> re.findall(r'a\Wc','abc')
  8. []
  9. >>> re.findall(r'a\Wc','a1c')
  10. []

数量词

(1)* 表示匹配前一个字符0~n次。假设表达式为abc*,则匹配ab、abc、abcc

  1. >>> re.findall(r'abc*','ab')
  2. ['ab']
  3. >>> re.findall(r'abc*','abc')
  4. ['abc']
  5. >>> re.findall(r'abc*','abcc')
  6. ['abcc']

(2)+ 表示匹配前一个字符1~n次。假设表达式为abc+,则匹配abc、abccc,不匹配ab

  1. >>> re.findall(r'abc+','abc')
  2. ['abc']
  3. >>> re.findall(r'abc+','abcc')
  4. ['abcc']
  5. >>> re.findall(r'abc+','ab')
  6. []

(3)? 表示匹配前一个字符0或1次。假设表达式为abc?,则匹配ab、abc

  1. >>> re.findall(r'abc?','ab')
  2. ['ab']
  3. >>> re.findall(r'abc?','abc')
  4. ['abc']

(4){m} 表示匹配前一个字符m次。假设表达式为abc{2},则匹配abcc,不匹配abc

  1. >>> re.findall(r'abc{2}','abcc')
  2. ['abcc']
  3. >>> re.findall(r'abc{2}','abc')
  4. []

(5){m,n} 表示匹配前一个字符m到n次。假设表达式为abc{2,3},则匹配abcc、abccc,不匹配abc

  1. >>> re.findall(r'abc{2,3}','abcc')
  2. ['abcc']
  3. >>> re.findall(r'abc{2,3}','abccc')
  4. ['abccc']
  5. >>> re.findall(r'abc{2,3}','abc')
  6. []

  数量词字符的描述到这里就结束,如果你仔细观察你会发现正则表达式abc*匹配abcc获取的结果是abcc而不是ab,表达式abc?匹配abc的结果是abc而不是ab,表达式abc{2,3}匹配abccc的结果不是abcc而是abccc。原因是正则表达式默认匹配方式是贪婪匹配,也就是最长匹配。所以会出现上述的匹配结果。那如果是想最短匹配呢?只需要在数量限定符后面加一个问号"?"就可以了。我们将上述的例子修改重新匹配下。实例如下:

  1. >>> re.findall(r'abc*','abcc') #最长匹配
  2. ['abcc']
  3. >>> re.findall(r'abc*?','abcc') #最短匹配
  4. ['ab']
  5. >>> re.findall(r'abc?','abc')
  6. ['abc']
  7. >>> re.findall(r'abc??','abc')
  8. ['ab']
  9. >>> re.findall(r'abc{2,3}','abccc')
  10. ['abccc']
  11. >>> re.findall(r'abc{2,3}?','abccc')
  12. ['abcc']

边界匹配

(1)^ 表示从字符串起始位置开始匹配。假设表达式为^abc,则匹配abcd,不匹配babc

  1. >>> re.findall(r'^abc','abcd')
  2. ['abc']
  3. >>> re.findall(r'^abc','babc')
  4. []

(2)$ 表示从字符串结尾开始匹配。假设表达式为abc$,则匹配ccabc,不匹配abcd

  1. >>> re.findall(r'abc$','ccabc')
  2. ['abc']
  3. >>> re.findall(r'abc$','ccabcd')
  4. []

(3)\A表示从 字符串起始位置开始匹配。 假设表达式为\Aabc,则匹配abcd,不匹配babc

  1. >>> re.findall(r'\Aabc','abcd')
  2. ['abc']
  3. >>> re.findall(r'\Aabc','babc')
  4. []

(4)\Z表示从字符串结束部分开始匹配。如果是存在换行,只匹配到换行前的结束字符串 假设表达式为abc\Z,则匹配abc,不匹配abcd

  1. >>> re.findall(r'abc\Z','abc')
  2. ['abc']
  3. >>> re.findall(r'abc\Z','abcd')
  4. []

(5)\b 表示匹配一个单词边界。假设表达式为'er\b' 则匹配"never" 中的 'er',但不能匹配 "verb" 中的 'er'。

  1. >>> re.findall(r'er\b','never')
  2. ['er']
  3. >>> re.findall(r'er\b','verb')
  4. []

(6)\B 表示匹配非单词边界。假设表达式为'er\B'则可以匹配 "verb" 中的 'er',但不能匹配 "never" 中的 'er'。

  1. >>> re.findall(r'er\B','verb')
  2. ['er']
  3. >>> re.findall(r'er\B','never')
  4. []

逻辑分组

(1)| 表示匹配|左右表达式的任意一个。假设表达式为abc|def,则匹配abc、def

  1. >>> re.findall(r'abc|def','abc')
  2. ['abc']
  3. >>> re.findall(r'abc|def','def')
  4. ['def']

(2)(...) 作为分组,每遇到一个(,分组编号加1,使用分组的好处是匹配的子串会保存到一个子组,便于以后使用。假设表达式为(\d{4})-(\d{2})-(\d{2}),则用于匹配2017-06-03,然后用分组编号1、2、3分别获取年、月、日三个值。。说明:如果这里match()函数和match对象的group()函数理解有困难,可以先跳过,后面再返回查看。

  1. >>> mat = re.search(r'(\d{4})-(\d{2})-(\d{2})','2017-06-03')
  2. >>> mat.group()
  3. '2017-06-03'
  4. >>> mat.group(1)
  5. ''
  6. >>> mat.group(2)
  7. ''
  8. >>> mat.group(3)
  9. ''

(3)(?P<name>...) 分组除原有编号外,再加一个别名 。假设表达式为(?P<Year>\d{4})-(?P<Month>\d{2})-(?P<Day>\d{2}),则匹配用于匹配2017-06-03,然后用命名分组名称Year、Month、Day获取年、月、日3个值。

  1. >>> mat = re.search(r'(?P<Year>\d{4})-(?P<Month>\d{2})-(?P<Day>\d{2})','2017-06-03')
  2. >>> mat.group()
  3. '2017-06-03'
  4. >>> mat.group('Year')
  5. ''
  6. >>> mat.group('Month')
  7. ''
  8. >>> mat.group('Day')
  9. ''

当然,在分组有命名的情况下也依然可以使用默认分组编号获取年、月、日的值。结果如下:

  1. >>> mat.group(1)
  2. ''
  3. >>> mat.group(2)
  4. ''
  5. >>> mat.group(3)
  6. ''

(4)\<number> 引用编号为number的分组匹配到的字符串。假设表达式为 (abc)ee\1,则匹配abceeabc,不匹配abceeabd。

  1. >>> re.match(r'(abc)ee\1','abceeabc') #match匹配则会有一个match对象返回。
  2. <_sre.SRE_Match object at 0x00000000055F9BE8>
  3. >>> re.match(r'(abc)ee\1','abceeabd') #match不匹配,则返回None。
  4. >>>

(5)(?P=name) 使用别名为name的分组匹配到的字符串。通常与(?P<name>...)结合使用。用法同\<number>。假设表达式为(?P<Year>\d{4})(?P=Year)。则匹配20172017,不匹配20172018。

  1. >>> mat = re.search(r'(?P<Year>\d{4})(?P=Year)','') #匹配,输出
  2. >>> mat.group()
  3. ''
  4. >>> mat.group(1)
  5. ''
  6. >>> re.search(r'(?P<Year>\d{4})(?P=Year)','') #不匹配,返回None
  7. >>>

字符串前r的含义

字符串前r表示不转义,使用真实字符。举例如下:

  1. >>> str = "Hello\tWorld"
  2. >>> print str
  3. Hello World
  4. >>> str = r"Hello\tWorld"
  5. >>> print str
  6. Hello\tWorld

re模块常用函数

1、match(pattern,string,flags=0)

根据pattern从string的头部开始匹配字符串,只返回第1次匹配成功的对象,否则,返回None。flags表示规则选项。

  1. >>> import re
  2. >>> Str='Python:Java:C'
  3. >>> re.match(r'Python',Str) #匹配成功
  4. <_sre.SRE_Match object at 0x0000000005C5FCC8>
  5. >>> Str='Java:Python:C'
  6. >>> re.match(r'Python',Str) #匹配失败
  7. >>>

2、search(pattern,string,flags=0)

根据pattern在string中匹配字符串,只返回第1次匹配成功的对象,否则,返回None。

  1. >>> import re
  2. >>> Str='Python:Java:C'
  3. >>> re.search(r'Python',Str) #匹配成功
  4. <_sre.SRE_Match object at 0x00000000060D7D98>
  5. >>> Str='Java:Python:C'
  6. >>> re.search(r'Python',Str) #同样匹配成功
  7. <_sre.SRE_Match object at 0x0000000005C5FCC8>

3、split(pattern,string,maxsplit=0)

根据pattern分隔string,maxsplit表示最大分隔数。

  1. >>> import re
  2. >>> Str='Python:Java:C'
  3. >>> re.split(r':',Str) #指定分隔符:
  4. ['Python', 'Java', 'C']
  5. >>> Str='Python:Java:C'
  6. >>> re.split(r':',Str,1) #指定最大分割次数
  7. ['Python', 'Java:C']
  8. >>> Str = "Python:Java:Shell|C++|Ruby"
  9. >>> re.split(r'[:|]',Str) #指定多种分隔符
  10. ['Python', 'Java', 'Shell', 'C++', 'Ruby']

4、compile(pattern,flags=0)

编译正则表达式pattern,返回一个pattern对象。

  1. >>> import re
  2. >>> regex = r'Python'
  3. >>> Str='Python:Java:C'
  4. >>> p = re.compile(regex)
  5. >>> p.match(Str)
  6. <_sre.SRE_Match object at 0x00000000060D7D98>

说明:pattern对象方法除了match(),还包括search()、findall()、finditer()。

5、sub(pattern,repl,string,count=0)

根据指定的正则表达式,替换字符串中的子串。pattern是一个正则表达式,repl是用于替换的字符串,string是源字符串,如果count为0,则返回string中匹配的所有结果。如果count>0,则返回前count个匹配结果。

  1. >>> import re
  2. >>> Str='Python:Java:C'
  3. >>> re.sub(r'P.*n','Ruby',Str)
  4. 'Ruby:Java:C'
  5. >>> print Str #不改变原字符串
  6. Python:Java:C

6、subn(pattern,repl,string,count=0)

作用和sub()相同,返回一个二元元组。第一个元素是替换结果,第2个元素是替换的次数。

  1. >>> import re
  2. >>> Str='Python:Java:C'
  3. >>> re.subn(r'P.*:','Ruby:',Str) #返回替换次数
  4. ('Ruby:C', 1)
  5. >>> re.subn(r'P.*?:','Ruby:',Str) #注意匹配中多了个?号,替换内容不同了
  6. ('Ruby:Java:C', 1)
  7. >>>

说明:匹配条件中'P.*?:'有无问号?号是有区别的。不加?号是贪婪匹配。

7、findall(pattern,string,flags=0)

根据pattern在string中匹配字符串。如果匹配成功,返回包含匹配结果的列表,否则,返回空列表。但pattern中有分组时,返回包含多个元组的列表,每个元组对应一个分组。

  1. >>> import re
  2. >>> regex = r'\w+' #\w表示匹配包括下划线的任何单词字符
  3. >>> Str='Python:Java:C'
  4. >>> p = re.compile(regex)
  5. >>> p.findall(Str)
  6. ['Python', 'Java', 'C']

描述完re模块的主要函数后,这里再强调 函数中的flags参数 和 re.compile() 函数。

1、re.flags参数

通过查看re模块函数的原型可以发现,函数参数几乎都有flags参数,该参数用于设置匹配的附加选项。例如,是否忽略大小写、是否支持多行匹配等。常用的re模块规则选项如下所示:

  1. IIGNORECASE 忽略大小写
  2. LLOCALE 字符集本地化,用于多语言环境
  3. MMULTILINE 多行匹配
  4. SDOTALL 使.匹配包括\n在内的所有字符
  5. XVERBOSE 忽略正则表达式中的空白、换行,方便添加注释
  6. UUNICODE \w\W\b\B\d\D\s\S都将使用Unicode

通过一个忽略大小写的实例看下用法:

  1. >>> import re
  2. >>> Str='Python:Java:C'
  3. >>> re.match(r'python',Str) #匹配失败
  4. >>> re.match(r'python',Str,re.I) #加re.I,匹配成功
  5. <_sre.SRE_Match object at 0x00000000060D7D98>

2、re.compile() 函数

正则表达式的解析非常耗时,如果多次使用findall()的方式匹配字符串搜索效率可能比较低。如果多次使用同一规则匹配字符串,可以使用compile()进行预编译,compile函数返回1个pattern对象。该对象拥有一系列方法用于查找、替换或扩展字符串,从而提供字符串的匹配速度。patter对象的属性和方法如下

  1. pattern #获取当前使用的正则表达式
  2. match(string,flags=0) #同re.match()
  3. search(string,flags=0) #同re.searc()
  4. findall(string,flags=0) #查找所有符合pattern对象匹配条件的结果,返回1个包含匹配结果的列表。
  5. finditer(string,flags=0) #返回一个包含匹配结果的地址

另外,函数compile()通常与match()、search()、group()一起使用对含有分组的正则表达式进行解析。正则表达式的分组从左往右开始计数,第1个出现的圆括号标记为第1组,依次类推。此外还有0号组,0号组用于存储匹配整个正则表达式的结果。match()和search()将返回一个match对象,match对象提供了一系列的方法和属性来管理匹配的结果。match对象的方法和属性如下:

  1. group(index=0) #某个分组的匹配结果。默认匹配整个正则表达式
  2. groups() #所有分组的匹配结果,每个分组的结果组成1个列表返回

举例,匹配身份证号码并获取身份证中的年、月、日信息。

  1. >>> regex = r'[1-9][0-9]{5}(\d{4})(\d{2})(\d{2})[0-9]{3}[0-9X]'
  2. >>> Str = '11010019950807532X'
  3. >>> p = re.compile(regex)
  4. >>> m = p.match(Str)
  5. >>> m.groups()
  6. ('', '', '')
  7. >>> m.group(1)
  8. ''
  9. >>> m.group(2)
  10. ''
  11. >>> m.group(3)
  12. ''

典型实例

1、多关键字任一匹配查找

  1. >>> import re
  2. >>> regex = r'Python|Java|C'
  3. >>> Str1 = 'Hello Java,Python Developer'
  4. >>> p = re.compile(regex)
  5. >>> p.findall(Str1)
  6. ['Java', 'Python']

说明:regex中的Python、Java、C表达式都可以单独作为一个匹配关键词在字符串中进行查找。也就是它们之间是 的关系。

2、提取字符串中的手机号码,手机号前缀为136,长度11位。

  1. >>> import re
  2. >>> Str = '13612345678,1361234567,123a2345678,136 12345678,13712345678,13687654321'
  3. >>> regex = r'136\d{8}'
  4. >>> p = re.compile(regex)
  5. >>> num_lst = p.findall(Str)
  6. >>> print num_lst
  7. ['', '']

3、利用分组命名,提取字符串中的内容

  1. >>> import re
  2. >>> Str = 'Learn 1998-07-12,Practice 1999-09-09,Complete 2000-01-01'
  3. >>> regex = r'(?P<year>[1-9]\d{3})-(?P<month>\d{2})-(?P<day>\d{2})'
  4. >>> p = re.compile(regex)
  5. >>> m = p.search(Str)
  6. >>> print m.group('year')
  7.  
  8. >>> print m.group('month')
  9.  
  10. >>> print m.group('day')

参考资料

1、python正则表达式及使用正则表达式的例子

Python正则表达式与re模块介绍的更多相关文章

  1. python正则表达式之re模块方法介绍

    python正则表达式之re模块其他方法 1:search(pattern,string,flags=0) 在一个字符串中查找匹配 2:findall(pattern,string,flags=0) ...

  2. python基础31[常用模块介绍]

    python基础31[常用模块介绍]   python除了关键字(keywords)和内置的类型和函数(builtins),更多的功能是通过libraries(即modules)来提供的. 常用的li ...

  3. python正则表达式与re模块-02

    正则表达式 正则表达式与python的关系 # 正则表达式不是Python独有的,它是一门独立的技术,所有的编程语言都可以使用正则 # 但要在python中使用正则表达式,就必须依赖于python内置 ...

  4. python 正则表达式re使用模块(match()、search()和compile())

    摘录 python核心编程 python的re模块允许多线程共享一个已编译的正则表达式对象,也支持命名子组.下表是常见的正则表达式属性: 函数/方法 描述 仅仅是re模块函数 compile(patt ...

  5. Python文件和目录模块介绍:glob、shutil、ConfigParser

    glob模块 查找符合特定规则的文件路径名,路径名可以使用绝对路径也可以使用相对路径.查找文件会使用到三个通配符,星号*,问号?和中括号[],其中"*"表示匹配0~n个字符, &q ...

  6. python 正则表达式 (重点) re模块

    京东的注册页面,打开页面我们就看到这些要求输入个人信息的提示.假如我们随意的在手机号码这一栏输入一个11111111111,它会提示我们格式有误.这个功能是怎么实现的呢?假如现在你用python写一段 ...

  7. Python正则表达式与hashlib模块

    菜鸟学python第十六天 1.re模块(正则表达式) 什么是正则表达式 正则表达式是一个由特殊字符组成的序列,他能帮助对字符串的某种对应模式进行查找. 在python中,re 模块使其拥有全部的正则 ...

  8. Python正则表达式与re模块

    在线正则表达式测试 http://tool.oschina.net/regex/ 常见匹配模式 模式 描述 \w 匹配字母数字及下划线 \W 匹配非字母数字下划线 \s 匹配任意空白字符,等价于 [\ ...

  9. python 正则表达式与re模块

    一.正则表达式 用途 用事先定义好的一些特定字符.及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑. #### 简单地说 就是用于字符串匹配的 字符组 在 ...

随机推荐

  1. vue 路由 以及默认路由跳转

    https://router.vuejs.org/ vue路由配置: 1.安装 npm install vue-router --save / cnpm install vue-router --sa ...

  2. SSH配置文件详解

    SSH:是一种安全通道协议,主要用来实现字符界面的远程登录,远程复制等功能. 在RHEL系统中SSH使用的是OpenSSH服务器,由opensh,openssh-server等软件包提供的. sshd ...

  3. C#存储过程中return参数

    //1 连接字符串 string connectionString = "server=127.0.0.1;integrated security=true;database=MSPetSh ...

  4. servlet的执行过程简介(从tomcat服务器和web应用的角度)

    该链接详解htttp请求和响应 http://www.cnblogs.com/goxcheer/p/8424175.html 1.web应用工程发布到tomcat服务器 2.客户端访问某个web资源, ...

  5. IIS 禁止回收

    在IIS中找到这个站点所用的程序池,点击“高级设置...” 在打开的列表中更改以下设置: 回收 ——固定时间间隔(分钟) 改为 0 ——虚拟/专用内存限制(KB) 改为 0 进程模型 ——闲置超时(分 ...

  6. 微信小程序学习笔记1--小程序的代码构成

    最近打算学习一下微信小程序,看了微信公众平台的文档感觉还比较简单,就从这个方向重新找回学习的状态吧: 1.先了解一下小程序的代码构成: 创建项目后会看到四种后缀的文件: .json 后缀的 JSON ...

  7. Linux TCP/IP调优-Linux内核参数注释

    固定文件的内核参数 下列文件所在目录: /proc/sys/net/ipv4/ 名称 默认值 建议值 描述 tcpsyn_retries 5 1 对于一个新建连接,内核要发送多少个SYN连接请求才决定 ...

  8. 更换Git的地址;

    Git地址变了,Android Studio更新和提交代码都用不了了:需要把新的Git地址更换一下: 1.打开git项目的文件夹,进入git操作框: 2. git remote -v 查看现有地址: ...

  9. Spring Boot 整合mybatis-generator

    Maven 引入 mybatis-generator插件 <build> <plugins> <plugin> <groupId>org.springf ...

  10. 闭包 -> 函数的嵌套

    内层函数对外层函数中的变量的使用 好处: 1. 保护变量不被侵害 2. 让一个变量常驻内存 如何通过代码查看一个闭包 __closure__: 有东西就是闭包. 没东西就不是闭包 # 闭包的优点: # ...