函數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彩蛋
知道就知道了,不知道你如今已經知道了,搜索一下去吧
微信搜索:非本科程序員,關注吧