python常用內(nèi)置模塊

持續(xù)更新中..


  • type(Object)
    傳入一個(gè)對象作為參數(shù),返回對象的類型
>>> type("abc")
<type 'str'>
>>> type(99)
<type 'int'>
  • cmp(Object1,Object2)
    對Object1和Object2進(jìn)行比較
    Object1 == Object2 返回0
    Object1 > Object2 返回正整型
    Object1 < Object2 返回負(fù)整型
>>> cmp("999","999")
0
>>> cmp("9999","999")
1
>>> cmp("999","9999")
-1

  • *isinstance(Object, arg)
    判斷Object的類型是否在arg元組中,若是返回True,否則返回False
>>> isinstance("sss",(list,int))
False
>>> isinstance("sss",(list,int,str))
True
>>> isinstance("sss",tuple)
False
  • str(Object) 與 repr(Object)
    宏觀上,二者都是傳入一個(gè)對象,返回這個(gè)對象的字符串化形式
    str()應(yīng)對用戶更友好,repr()應(yīng)對python解釋器更友好
    實(shí)際上是由類內(nèi)建方法_str(self) _repr(self)來實(shí)現(xiàn)
>>> a = ("a",2,("s",2))
>>> repr(a)
"('a', 2, ('s', 2))"
>>> str(a)
"('a', 2, ('s', 2))"
  • divmod(Num1,Num2)
    返回Num1/Num2的商和余數(shù)的元組
    (Num1/Num2,Num1%Num2)
>>> divmod(10,3)
(3, 1)
>>> divmod(8,2)
(4, 0)
  • oct(Num)與hex(Num)
    傳入一個(gè)十進(jìn)制數(shù),轉(zhuǎn)換為八進(jìn)制、十六進(jìn)制
>>> oct(10)
'012'
>>> hex(10)
'0xa'
  • ord(Char)與chr(num)
    前者傳入字符返回ASCLL碼,后者傳入ASCLL碼返回字符
>>> ord('X')
88
>>> chr(67)
'C'
  • Decimal(Stirng)
    傳入一個(gè)內(nèi)容為浮點(diǎn)數(shù)的字符串,返回一個(gè)decimal對象,用于精確浮點(diǎn)數(shù)計(jì)算

注:需要導(dǎo)入decimal模塊

>>> from decimal import Decimal
>>> dec = Decimal('0.000002')
>>> dec
Decimal('0.000002')
>>> dec2=Decimal("0.000003")
>>> dec2
Decimal('0.000003')
>>> dec+dec2
Decimal('0.000005')
>>> from decimal import Decimal
>>> dec1 = Decimal("2.000000000009")
>>> dec2 = Decimal("3.9999999000001")
>>> dec1 + dec2
Decimal('5.9999999000091')
>>> type(dec1)
<class 'decimal.Decimal'>
  • random模塊
    python內(nèi)置提供隨機(jī)方法的模塊
  • randint(start,end)
    傳入兩個(gè)整型參數(shù),返回二者之間的一個(gè)隨機(jī)整型(包含首位)
  • randrange([start=0],end,[step=1])
    可傳入3個(gè)整型參數(shù)(第三個(gè)為步進(jìn)),返回之間的一個(gè)隨機(jī)整型,不包含end
  • uniform(start,end)
    傳入兩個(gè)數(shù)字參數(shù),返回二者之間的一個(gè)浮點(diǎn)型
  • random()
    類似于uniform(),但是上下限,恒等于[0.0, 1.0]
  • choice(Sequence)
    傳入一個(gè)序列,返回序列中的一個(gè)元素
>>> import random
>>> random.randint(1,100)
59
>>> random.randrange(1,100,2)
11
>>> random.uniform(1,100)
82.08486083329718
>>> random.random()
0.04396359706229158
>>> list1 = ["a",1,"b"]
>>> random.choice(list1)
1
  • range(end,start=0,step=1)
    傳入?yún)?shù),返回一個(gè)列表,不含end
>>> range(0,5,2)
[0, 2, 4]
>>> range(6)
[0, 1, 2, 3, 4, 5]
  • xrange(end,start=0,step=1)
    傳入?yún)?shù),返回一個(gè)列表生成器,列表不含end
    注:比range節(jié)省內(nèi)存,但增大計(jì)算開銷
>>> a = xrange(6)
>>> b = xrange(1,9,2)
>>> [ x for x in a]
[0, 1, 2, 3, 4, 5]
>>> [ x for x in b]
[1, 3, 5, 7]
  • enumerate(iterate)
    傳入一個(gè)可迭代的參數(shù),返回一個(gè)iterate對象,每次迭代返回(index,value)元祖
>>> a = range(5)
>>> [ x for x in enumerate(a) ]
[(0, 0), (1, 1), (2, 2), (3, 3), (4, 4)]
  • zip(Sequence1,Sequence2)
    傳入2個(gè)序列,返回一個(gè)列表,其第一個(gè)元素為這2個(gè)序列第一個(gè)元素所組成的元祖,以此類推
>>> list1 = range(3)
>>> list2 = range(5)
>>> zip(list1,list2)
[(0, 0), (1, 1), (2, 2)]
  • sorted(Iterate,cmp=None,key=None,reverse=False)
    排序方法,傳入一個(gè)可迭代對象,也可提供key,cmp,reverse
>>> a = [5,4,3,2,1]
>>> sorted(a)
[1, 2, 3, 4, 5]
>>> b = [1,2,3,4,5]
>>> sorted(b, reverse=True)
[5, 4, 3, 2, 1]
>>> c = zip(b,a)
>>> sorted(c,key = lambda x:x[1])
[(5, 1), (4, 2), (3, 3), (2, 4), (1, 5)]
>>> sorted(c, cmp = lambda x,y:cmp(x[1],y[1]))
[(5, 1), (4, 2), (3, 3), (2, 4), (1, 5)]
  • list內(nèi)置模塊
    • list1.extend(list2)
      將list2的元素追加到list1中
      注意:相比于列表相+,extend更省內(nèi)存
>>> a = [1,2,3]
>>> b= [4,5,6]
>>> a.extend(b)
>>> a
[1, 2, 3, 4, 5, 6]
  • string內(nèi)置模塊
    • string.find(str)
      在string中從左開始尋找第一個(gè)匹配str的位置,若無匹配返回-1
>>> a = "aaajjjkkkjjj"
>>> a.find("jjj")
3
>>> a.find("love")
-1
  • string.rfind(str)
    在string中從右開始尋找第一個(gè)匹配str的位置,若無匹配返回-1
>>> a = "aaajjjkkkjjj"
>>> a.rfind("jjj")
9
>>> a.find("love")
-1
  • string.index(str)與string.rindex(str)
    與find類似,但未匹配會報(bào)異常
>>> a.index("jjj")
3
>>> a.rindex("jjj")
9
>>> a.index("bbb")
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: substring not found
  • string.join(Sequence)
    將序列中各元素以string作分割組成字符串
    注:Sequnece中元素為可與string連接的類型
>>> a = [ chr(x) for x in range(49,58)]
>>> a
['1', '2', '3', '4', '5', '6', '7', '8', '9']
>>> "|".join(a)
'1|2|3|4|5|6|7|8|9'
  • string.strip(str=‘ ’),lstrip,rstrip
    刪除string開頭和結(jié)尾的str字符
    注,strip()由lstrip()和rstrip()組成
>>> str1 = "aasssaa"
>>> str1.strip("a")
'sss'
  • string.replace(str1,str2)
>>> s = "a11a11a11aa11"
>>> s.replace("11","22")
'a22a22a22aa22'
  • string.split(str)
    對string以str為分割進(jìn)行切片,返回一個(gè)列表
>>> s = "a11a11a11aa11"
>>> s.split('1')
['a', '', 'a', '', 'a', '', 'aa', '', '']
>>> s.split('11')
['a', 'a', 'a', 'aa', '']
  • string.decode(str)
    將string從str格式解碼為unicode格式
>>> S = "蟒蛇"
>>> A = S.decode("utf8")
>>> A
u'\u87d2\u86c7'
  • string.encode(str)
    將string從Unicode編碼為str格式
>>> C = A.encode("utf8")
>>> C
'\xe8\x9f\x92\xe8\x9b\x87'
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容