函数tuple(seq)
能够把全部可迭代的(iterable)序列
转换成一个tuple
, 元素不变,排序也不变python
list转为tuple:程序员
temp_list = [1,2,3,4,5]
复制代码
将temp_list进行强制转换:tuple(temp_list)
肯定是否转换成功:print(type(temp_list))
shell
函数list(seq)
能够把全部的序列和可迭代的对象
转换成一个list,元素不变,排序也不变微信
tuple 转为list:函数
temp_tuple = (1,2,3,4,5)
复制代码
方法相似,也是进行强制转换便可:list(temp_tuple)
肯定是否转换成功:print(type(temp_tuple))
性能
它们两个都在re模块
中优化
match()
函数是在string的开始位置匹配,若是不匹配,则返回None;search()
会扫描整个string查找匹配;>>> import re
>>> print(re.match('hello','helloworld').span()) # 开头匹配到
(0, 5)
>>> print(re.match('hello','nicehelloworld').span()) # 开头没有匹配到
Traceback (most recent call last):
File "<pyshell#2>", line 1, in <module>
print(re.match('hello','nicehelloworld').span())
AttributeError: 'NoneType' object has no attribute 'span'
>>>
复制代码
>>> print(re.search('a','abc'))
<_sre.SRE_Match object; span=(0, 1), match='a'>
>>> print(re.search('a','bac').span())
(1, 2)
>>>
复制代码
结论:match() 使用限制更多this
os模块的使用spa
os.remove(path)
code
删除文件 path,删除时候若是path是一个目录, 抛出 OSError错误。若是要删除目录,请使用rmdir()。
remove() 同 unlink() 的功能是同样的
os.remove('a.txt')
复制代码
os.removedirs(path)
递归地删除目录。相似于rmdir()
, 若是子目录被成功删除, removedirs()
将会删除父目录;但子目录没有成功删除,将抛出错误。
例如, os.removedirs(“a/b/c”)
将首先删除c
目录,而后再删除b
和a
, 若是他们是空的话,则子目录不能成功删除,将抛出 OSError异常
os.rmdir(path)
删除目录 path,要求path必须是个空目录
,不然抛出OSError错误
hon中对象包含的三个基本要素,分别是:
id(身份标识)
、type(数据类型)
和value(值)
id 身份标识,就是在内存中的地址
完整的举例
>>> a = 'hello'
>>> b = 'hello'
>>> print(a is b)
True
>>> print(a==b)
True
>>> a = 'hello world'
>>> b = 'hello world'
>>> print(a is b)
False
>>> print(a == b)
True
>>> a = [1,2,3]
>>> b = [1,2,3]
>>> print(a is b)
False
>>> print(a == b)
True
>>> a = [1,2,3]
>>> b = a
>>> print(a is b)
True
>>> print(a == b)
True
>>>
复制代码
==
是python标准操做符中的比较操做符
,用来比较判断两个对象的value(值)
是否相等is
也被叫作同一性运算符(对象标示符),这个运算符比较判断的是对象间的惟一身份标识
,也就是id
(内存中的地址)是否相同咱们在检查 a is b 的时候,其实至关于检查 id(a) == id(b)
。而检查a == b
的时候,实际是调用了对象 a 的 __eq()__
方法,a == b
至关于 a.__eq__(b)
。
这里还有一个问题,为何 a 和 b 都是 "hello" 的时候,a is b 返回True,而 a 和 b都是 "hello world" 的时候,a is b 返回False呢?
这是由于前一种状况下Python的字符串驻留机制
起了做用。对于较小的字符串,为了提升系统性能Python会保留其值的一个副本,当建立新的字符串的时候直接指向该副本便可。
因此 "hello" 在内存中只有一个副本,a 和 b 的 id 值相同,而 "hello world" 是长字符串,不驻留内存,Python中各自建立了对象来表示 a 和 b,因此他们的值相同但 id 值不一样。
试一下当a=247
,b=247
时它们的id仍是否会相等。事实上Python 为了优化速度,使用了小整数对象池,避免为整数频繁申请和销毁内存空间。而Python 对小整数的定义是 [-5, 257),只有数字在-5到256之间它们的id才会相等,超过了这个范围就不行了。
>>> a = 247
>>> b = 247
>>> print(a is b)
True
>>> a = 258
>>> b = 258
>>> print(a is b)
False
>>>
复制代码
is 是检查两个对象是否指向同一块内存空间,而
==
是检查他们的值是否相等。is比==
更加严格
方法一
>>> a = 5
>>> b = 6
>>> a = a+b
>>> b = a-b
>>> a = a-b
复制代码
方法二
>>> a = a^b
>>> b = b^a
>>> a = a^b
复制代码
方法三
a,b = b,a
复制代码
Python之禅 import this
python彩蛋
知道就知道了,不知道你如今已经知道了,搜索一下去吧
微信搜索:非本科程序员,关注吧