一般來(lái)說(shuō),handle就相當(dāng)于C中的函數(shù)指針,你把哪個(gè)函數(shù)的句柄賦給handle,handle就代表哪個(gè)函數(shù)。當(dāng)然,你也可以自己定義一個(gè)handle。
青岡ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書(shū)未來(lái)市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)建站的ssl證書(shū)銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18982081108(備注:SSL證書(shū)合作)期待與您的合作!
1、首先。點(diǎn)擊進(jìn)入點(diǎn)擊設(shè)置,進(jìn)入窗口設(shè)置。
2、其次。點(diǎn)擊綁定搞到大數(shù)據(jù)窗口綁定,然后找找到python然后點(diǎn)擊綁定窗口句柄。
3、最后。點(diǎn)擊確定,python綁定窗口句柄就可以了。
點(diǎn)擊上方 "Python人工智能技術(shù)" 關(guān)注,星標(biāo)或者置頂
22點(diǎn)24分準(zhǔn)時(shí)推送,第一時(shí)間送達(dá)
后臺(tái)回復(fù)“大禮包”,送你特別福利
編輯:樂(lè)樂(lè) | 來(lái)自:pypypypy
上一篇:
正文
大家好,我是Pythn人工智能技術(shù)。
內(nèi)置函數(shù)就是Python給你提供的,拿來(lái)直接用的函數(shù),比如print.,input等。
截止到python版本3.6.2 ,python一共提供了68個(gè)內(nèi)置函數(shù),具體如下
abs() dict() help() min() setattr()
all() dir() hex() next() slice()
any() divmod() id() object() sorted()
ascii() enumerate() input() oct() staticmethod()
bin() eval() int() open() str()
bool() exec() isinstance() ord() sum()
bytearray() ?lter() issubclass() pow() super()
bytes() ?oat() iter() print() tuple()
callable() format() len() property() type()
chr() frozenset() list() range() vars()
classmethod() getattr() locals() repr() zip()
compile() globals() map() reversed() __import__()
complex() hasattr() max() round()
delattr() hash() memoryview() set()
本文將這68個(gè)內(nèi)置函數(shù)綜合整理為12大類,正在學(xué)習(xí)Python基礎(chǔ)的讀者一定不要錯(cuò)過(guò),建議收藏學(xué)習(xí)!
和數(shù)字相關(guān) 1. 數(shù)據(jù)類型
bool : 布爾型(True,False)
int : 整型(整數(shù))
float : 浮點(diǎn)型(小數(shù))
complex : 復(fù)數(shù)
2. 進(jìn)制轉(zhuǎn)換
bin() 將給的參數(shù)轉(zhuǎn)換成二進(jìn)制
otc() 將給的參數(shù)轉(zhuǎn)換成八進(jìn)制
hex() 將給的參數(shù)轉(zhuǎn)換成十六進(jìn)制
print(bin(10)) # 二進(jìn)制:0b1010
print(hex(10)) # 十六進(jìn)制:0xa
print(oct(10)) # 八進(jìn)制:0o12
3. 數(shù)學(xué)運(yùn)算
abs() 返回絕對(duì)值
divmode() 返回商和余數(shù)
round() 四舍五入
pow(a, b) 求a的b次冪, 如果有三個(gè)參數(shù). 則求完次冪后對(duì)第三個(gè)數(shù)取余
sum() 求和
min() 求最小值
max() 求最大值
print(abs(-2)) # 絕對(duì)值:2
print(divmod(20,3)) # 求商和余數(shù):(6,2)
print(round(4.50)) # 五舍六入:4
print(round(4.51)) #5
print(pow(10,2,3)) # 如果給了第三個(gè)參數(shù). 表示最后取余:1
print(sum([1,2,3,4,5,6,7,8,9,10])) # 求和:55
print(min(5,3,9,12,7,2)) #求最小值:2
print(max(7,3,15,9,4,13)) #求最大值:15
和數(shù)據(jù)結(jié)構(gòu)相關(guān) 1. 序列
(1)列表和元組
list() 將一個(gè)可迭代對(duì)象轉(zhuǎn)換成列表
tuple() 將一個(gè)可迭代對(duì)象轉(zhuǎn)換成元組
print(list((1,2,3,4,5,6))) #[1, 2, 3, 4, 5, 6]
print(tuple([1,2,3,4,5,6])) #(1, 2, 3, 4, 5, 6)
(2)相關(guān)內(nèi)置函數(shù)
reversed() 將一個(gè)序列翻轉(zhuǎn), 返回翻轉(zhuǎn)序列的迭代器
slice() 列表的切片
lst = "你好啊"
it = reversed(lst) # 不會(huì)改變?cè)斜? 返回一個(gè)迭代器, 設(shè)計(jì)上的一個(gè)規(guī)則
print(list(it)) #['啊', '好', '你']
lst = [1, 2, 3, 4, 5, 6, 7]
print(lst[1:3:1]) #[2,3]
s = slice(1, 3, 1) # 切片用的
print(lst[s]) #[2,3]
(3)字符串
str() 將數(shù)據(jù)轉(zhuǎn)化成字符串
print(str(123)+'456') #123456
format() 與具體數(shù)據(jù)相關(guān), 用于計(jì)算各種小數(shù), 精算等.
s = "hello world!"
print(format(s, "^20")) #劇中
print(format(s, "20")) #左對(duì)齊
print(format(s, "20")) #右對(duì)齊
# hello world!
# hello world!
# hello world!
print(format(3, 'b' )) # 二進(jìn)制:11
print(format(97, 'c' )) # 轉(zhuǎn)換成unicode字符:a
print(format(11, 'd' )) # ?進(jìn)制:11
print(format(11, 'o' )) # 八進(jìn)制:13
print(format(11, 'x' )) # 十六進(jìn)制(?寫(xiě)字母):b
print(format(11, 'X' )) # 十六進(jìn)制(大寫(xiě)字母):B
print(format(11, 'n' )) # 和d?樣:11
print(format(11)) # 和d?樣:11
print(format(123456789, 'e' )) # 科學(xué)計(jì)數(shù)法. 默認(rèn)保留6位小數(shù):1.234568e+08
print(format(123456789, '0.2e' )) # 科學(xué)計(jì)數(shù)法. 保留2位小數(shù)(小寫(xiě)):1.23e+08
print(format(123456789, '0.2E' )) # 科學(xué)計(jì)數(shù)法. 保留2位小數(shù)(大寫(xiě)):1.23E+08
print(format(1.23456789, 'f' )) # 小數(shù)點(diǎn)計(jì)數(shù)法. 保留6位小數(shù):1.234568
print(format(1.23456789, '0.2f' )) # 小數(shù)點(diǎn)計(jì)數(shù)法. 保留2位小數(shù):1.23
print(format(1.23456789, '0.10f')) # 小數(shù)點(diǎn)計(jì)數(shù)法. 保留10位小數(shù):1.2345678900
print(format(1.23456789e+3, 'F')) # 小數(shù)點(diǎn)計(jì)數(shù)法. 很大的時(shí)候輸出INF:1234.567890
bytes() 把字符串轉(zhuǎn)化成bytes類型
bs = bytes("今天吃飯了嗎", encoding="utf-8")
print(bs) #b'\xe4\xbb\x8a\xe5\xa4\xa9\xe5\x90\x83\xe9\xa5\xad\xe4\xba\x86\xe5\x90\x97'
bytearray() 返回一個(gè)新字節(jié)數(shù)組. 這個(gè)數(shù)字的元素是可變的, 并且每個(gè)元素的值得范圍是[0,256)
ret = bytearray("alex" ,encoding ='utf-8')
print(ret[0]) #97
print(ret) #bytearray(b'alex')
ret[0] = 65 #把65的位置A賦值給ret[0]
print(str(ret)) #bytearray(b'Alex')
ord() 輸入字符找?guī)ё址幋a的位置
chr() 輸入位置數(shù)字找出對(duì)應(yīng)的字符
ascii() 是ascii碼中的返回該值 不是就返回u
print(ord('a')) # 字母a在編碼表中的碼位:97
print(ord('中')) # '中'字在編碼表中的位置:20013
print(chr(65)) # 已知碼位,求字符是什么:A
print(chr(19999)) #丟
for i in range(65536): #打印出0到65535的字符
print(chr(i), end=" ")
print(ascii("@")) #'@'
repr() 返回一個(gè)對(duì)象的string形式
s = "今天\n吃了%s頓\t飯" % 3
print(s)#今天# 吃了3頓 飯
print(repr(s)) # 原樣輸出,過(guò)濾掉轉(zhuǎn)義字符 \n \t \r 不管百分號(hào)%
#'今天\n吃了3頓\t飯'
2. 數(shù)據(jù)集合
字典:dict 創(chuàng)建一個(gè)字典
集合:set 創(chuàng)建一個(gè)集合
frozenset() 創(chuàng)建一個(gè)凍結(jié)的集合,凍結(jié)的集合不能進(jìn)行添加和刪除操作。
3. 相關(guān)內(nèi)置函數(shù)
len() 返回一個(gè)對(duì)象中的元素的個(gè)數(shù)
sorted() 對(duì)可迭代對(duì)象進(jìn)行排序操作 (lamda)
語(yǔ)法:sorted(Iterable, key=函數(shù)(排序規(guī)則), reverse=False)
Iterable: 可迭代對(duì)象
key: 排序規(guī)則(排序函數(shù)), 在sorted內(nèi)部會(huì)將可迭代對(duì)象中的每一個(gè)元素傳遞給這個(gè)函數(shù)的參數(shù). 根據(jù)函數(shù)運(yùn)算的結(jié)果進(jìn)行排序
reverse: 是否是倒敘. True: 倒敘, False: 正序
lst = [5,7,6,12,1,13,9,18,5]
lst.sort() # sort是list里面的一個(gè)方法
print(lst) #[1, 5, 5, 6, 7, 9, 12, 13, 18]
ll = sorted(lst) # 內(nèi)置函數(shù). 返回給你一個(gè)新列表 新列表是被排序的
print(ll) #[1, 5, 5, 6, 7, 9, 12, 13, 18]
l2 = sorted(lst,reverse=True) #倒序
print(l2) #[18, 13, 12, 9, 7, 6, 5, 5, 1]
#根據(jù)字符串長(zhǎng)度給列表排序
lst = ['one', 'two', 'three', 'four', 'five', 'six']
def f(s):
return len(s)
l1 = sorted(lst, key=f, )
print(l1) #['one', 'two', 'six', 'four', 'five', 'three']
enumerate() 獲取集合的枚舉對(duì)象
lst = ['one','two','three','four','five']
for index, el in enumerate(lst,1): # 把索引和元素一起獲取,索引默認(rèn)從0開(kāi)始. 可以更改
print(index)
print(el)
# 1
# one
# 2
# two
# 3
# three
# 4
# four
# 5
# five
all() 可迭代對(duì)象中全部是True, 結(jié)果才是True
any() 可迭代對(duì)象中有一個(gè)是True, 結(jié)果就是True
print(all([1,'hello',True,9])) #True
print(any([0,0,0,False,1,'good'])) #True
zip() 函數(shù)用于將可迭代的對(duì)象作為參數(shù), 將對(duì)象中對(duì)應(yīng)的元素打包成一個(gè)元組, 然后返回由這些元組組成的列表. 如果各個(gè)迭代器的元素個(gè)數(shù)不一致, 則返回列表長(zhǎng)度與最短的對(duì)象相同
lst1 = [1, 2, 3, 4, 5, 6]
lst2 = ['醉鄉(xiāng)民謠', '驢得水', '放牛班的春天', '美麗人生', '辯護(hù)人', '被嫌棄的松子的一生']
lst3 = ['美國(guó)', '中國(guó)', '法國(guó)', '意大利', '韓國(guó)', '日本']
print(zip(lst1, lst1, lst3)) #
for el in zip(lst1, lst2, lst3):
print(el)
# (1, '醉鄉(xiāng)民謠', '美國(guó)')
# (2, '驢得水', '中國(guó)')
# (3, '放牛班的春天', '法國(guó)')
# (4, '美麗人生', '意大利')
# (5, '辯護(hù)人', '韓國(guó)')
# (6, '被嫌棄的松子的一生', '日本')
fiter() 過(guò)濾 (lamda)
語(yǔ)法:fiter(function. Iterable)
function: 用來(lái)篩選的函數(shù). 在?lter中會(huì)自動(dòng)的把iterable中的元素傳遞給function. 然后根據(jù)function返回的True或者False來(lái)判斷是否保留留此項(xiàng)數(shù)據(jù) , Iterable: 可迭代對(duì)象
搜索公眾號(hào)頂級(jí)架構(gòu)師后臺(tái)回復(fù)“面試”,送你一份驚喜禮包。
def func(i): # 判斷奇數(shù)
return i % 2 == 1
lst = [1,2,3,4,5,6,7,8,9]
l1 = filter(func, lst) #l1是迭代器
print(l1) #
print(list(l1)) #[1, 3, 5, 7, 9]
map() 會(huì)根據(jù)提供的函數(shù)對(duì)指定序列列做映射(lamda)
語(yǔ)法 : map(function, iterable)
可以對(duì)可迭代對(duì)象中的每一個(gè)元素進(jìn)行映射. 分別去執(zhí)行 function
def f(i): return i
lst = [1,2,3,4,5,6,7,]
it = map(f, lst) # 把可迭代對(duì)象中的每一個(gè)元素傳遞給前面的函數(shù)進(jìn)行處理. 處理的結(jié)果會(huì)返回成迭代器print(list(it)) #[1, 2, 3, 4, 5, 6, 7]
和作用域相關(guān)
locals() 返回當(dāng)前作用域中的名字
globals() 返回全局作用域中的名字
def func():
a = 10
print(locals()) # 當(dāng)前作用域中的內(nèi)容
print(globals()) # 全局作用域中的內(nèi)容
print("今天內(nèi)容很多")
func()
# {'a': 10}
# {'__name__': '__main__', '__doc__': None, '__package__': None, '__loader__':
# _frozen_importlib_external.SourceFileLoader object at 0x0000026F8D566080,
# '__spec__': None, '__annotations__': {}, '__builtins__':
# (built-in), '__file__': 'D:/pycharm/練習(xí)/week03/new14.py', '__cached__': None,
# 'func': }
# 今天內(nèi)容很多
和迭代器生成器相關(guān)
range() 生成數(shù)據(jù)
next() 迭代器向下執(zhí)行一次, 內(nèi)部實(shí)際使?用了__ next__()?方法返回迭代器的下一個(gè)項(xiàng)目
iter() 獲取迭代器, 內(nèi)部實(shí)際使用的是__ iter__()?方法來(lái)獲取迭代器
for i in range(15,-1,-5):
print(i)
# 15
# 10
# 5
# 0
lst = [1,2,3,4,5]
it = iter(lst) # __iter__()獲得迭代器
print(it.__next__()) #1
print(next(it)) #2 __next__()
print(next(it)) #3
print(next(it)) #4
字符串類型代碼的執(zhí)行
eval() 執(zhí)行字符串類型的代碼. 并返回最終結(jié)果
exec() 執(zhí)行字符串類型的代碼
compile() 將字符串類型的代碼編碼. 代碼對(duì)象能夠通過(guò)exec語(yǔ)句來(lái)執(zhí)行或者eval()進(jìn)行求值
s1 = input("請(qǐng)輸入a+b:") #輸入:8+9
print(eval(s1)) # 17 可以動(dòng)態(tài)的執(zhí)行代碼. 代碼必須有返回值
s2 = "for i in range(5): print(i)"
a = exec(s2) # exec 執(zhí)行代碼不返回任何內(nèi)容
# 0
# 1
# 2
# 3
# 4
print(a) #None
# 動(dòng)態(tài)執(zhí)行代碼
exec("""
def func():
print(" 我是周杰倫")
""" )
func() #我是周杰倫
code1 = "for i in range(3): print(i)"
com = compile(code1, "", mode="exec") # compile并不會(huì)執(zhí)行你的代碼.只是編譯
exec(com) # 執(zhí)行編譯的結(jié)果
# 0
# 1
# 2
code2 = "5+6+7"
com2 = compile(code2, "", mode="eval")
print(eval(com2)) # 18
code3 = "name = input('請(qǐng)輸入你的名字:')" #輸入:hello
com3 = compile(code3, "", mode="single")
exec(com3)
print(name) #hello
輸入輸出
print() : 打印輸出
input() : 獲取用戶輸出的內(nèi)容
print("hello", "world", sep="*", end="@") # sep:打印出的內(nèi)容用什么連接,end:以什么為結(jié)尾
#hello*world@
內(nèi)存相關(guān)
hash() : 獲取到對(duì)象的哈希值(int, str, bool, tuple). hash算法:(1) 目的是唯一性 (2) dict 查找效率非常高, hash表.用空間換的時(shí)間 比較耗費(fèi)內(nèi)存
s = 'alex'print(hash(s)) #-168324845050430382lst = [1, 2, 3, 4, 5]print(hash(lst)) #報(bào)錯(cuò),列表是不可哈希的 id() : 獲取到對(duì)象的內(nèi)存地址s = 'alex'print(id(s)) #2278345368944
文件操作相關(guān)
open() : 用于打開(kāi)一個(gè)文件, 創(chuàng)建一個(gè)文件句柄
f = open('file',mode='r',encoding='utf-8')
f.read()
f.close()
模塊相關(guān)
__ import__() : 用于動(dòng)態(tài)加載類和函數(shù)
# 讓用戶輸入一個(gè)要導(dǎo)入的模塊
import os
name = input("請(qǐng)輸入你要導(dǎo)入的模塊:")
__import__(name) # 可以動(dòng)態(tài)導(dǎo)入模塊
幫 助
help() : 函數(shù)用于查看函數(shù)或模塊用途的詳細(xì)說(shuō)明
print(help(str)) #查看字符串的用途
調(diào)用相關(guān)
callable() : 用于檢查一個(gè)對(duì)象是否是可調(diào)用的. 如果返回True, object有可能調(diào)用失敗, 但如果返回False. 那調(diào)用絕對(duì)不會(huì)成功
a = 10
print(callable(a)) #False 變量a不能被調(diào)用
def f():
print("hello")
print(callable(f)) # True 函數(shù)是可以被調(diào)用的
查看內(nèi)置屬性
dir() : 查看對(duì)象的內(nèi)置屬性, 訪問(wèn)的是對(duì)象中的__dir__()方法
print(dir(tuple)) #查看元組的方法
你還有什么想要補(bǔ)充的嗎?
免責(zé)聲明:本文內(nèi)容來(lái)源于網(wǎng)絡(luò),文章版權(quán)歸原作者所有,意在傳播相關(guān)技術(shù)知識(shí)行業(yè)趨勢(shì),供大家學(xué)習(xí)交流,若涉及作品版權(quán)問(wèn)題,請(qǐng)聯(lián)系刪除或授權(quán)事宜。
技術(shù)君個(gè)人微信
添加技術(shù)君個(gè)人微信即送一份驚喜大禮包
→ 技術(shù)資料共享
→ 技術(shù)交流社群
--END--
往日熱文:
Python程序員深度學(xué)習(xí)的“四大名著”:
這四本書(shū)著實(shí)很不錯(cuò)!我們都知道現(xiàn)在機(jī)器學(xué)習(xí)、深度學(xué)習(xí)的資料太多了,面對(duì)海量資源,往往陷入到“無(wú)從下手”的困惑出境。而且并非所有的書(shū)籍都是優(yōu)質(zhì)資源,浪費(fèi)大量的時(shí)間是得不償失的。給大家推薦這幾本好書(shū)并做簡(jiǎn)單介紹。
獲得方式:
2.后臺(tái)回復(fù)關(guān)鍵詞:名著
這份資料非常純粹,只有Python的基礎(chǔ)語(yǔ)法,專門(mén)針對(duì)想要學(xué)習(xí)Python的小白。
Python中用#表示單行注釋,#之后的同行的內(nèi)容都會(huì)被注釋掉。
使用三個(gè)連續(xù)的雙引號(hào)表示多行注釋,兩個(gè)多行注釋標(biāo)識(shí)之間內(nèi)容會(huì)被視作是注釋。
Python當(dāng)中的數(shù)字定義和其他語(yǔ)言一樣:
我們分別使用+, -, *, /表示加減乘除四則運(yùn)算符。
這里要注意的是,在Python2當(dāng)中,10/3這個(gè)操作會(huì)得到3,而不是3.33333。因?yàn)槌龜?shù)和被除數(shù)都是整數(shù),所以Python會(huì)自動(dòng)執(zhí)行整數(shù)的計(jì)算,幫我們把得到的商取整。如果是10.0 / 3,就會(huì)得到3.33333。目前Python2已經(jīng)不再維護(hù)了,可以不用關(guān)心其中的細(xì)節(jié)。
但問(wèn)題是Python是一個(gè) 弱類型 的語(yǔ)言,如果我們?cè)谝粋€(gè)函數(shù)當(dāng)中得到兩個(gè)變量,是無(wú)法直接判斷它們的類型的。這就導(dǎo)致了同樣的計(jì)算符可能會(huì)得到不同的結(jié)果,這非常蛋疼。以至于程序員在運(yùn)算除法的時(shí)候,往往都需要手工加上類型轉(zhuǎn)化符,將被除數(shù)轉(zhuǎn)成浮點(diǎn)數(shù)。
在Python3當(dāng)中撥亂反正,修正了這個(gè)問(wèn)題,即使是兩個(gè)整數(shù)相除,并且可以整除的情況下,得到的結(jié)果也一定是浮點(diǎn)數(shù)。
如果我們想要得到整數(shù),我們可以這么操作:
兩個(gè)除號(hào)表示 取整除 ,Python會(huì)為我們保留去除余數(shù)的結(jié)果。
除了取整除操作之外還有取余數(shù)操作,數(shù)學(xué)上稱為取模,Python中用%表示。
Python中支持 乘方運(yùn)算 ,我們可以不用調(diào)用額外的函數(shù),而使用**符號(hào)來(lái)完成:
當(dāng)運(yùn)算比較復(fù)雜的時(shí)候,我們可以用括號(hào)來(lái)強(qiáng)制改變運(yùn)算順序。
Python中用首字母大寫(xiě)的True和False表示真和假。
用and表示與操作,or表示或操作,not表示非操作。而不是C++或者是Java當(dāng)中的, || 和!。
在Python底層, True和False其實(shí)是1和0 ,所以如果我們執(zhí)行以下操作,是不會(huì)報(bào)錯(cuò)的,但是在邏輯上毫無(wú)意義。
我們用==判斷相等的操作,可以看出來(lái)True==1, False == 0.
我們要小心Python當(dāng)中的bool()這個(gè)函數(shù),它并不是轉(zhuǎn)成bool類型的意思。如果我們執(zhí)行這個(gè)函數(shù),那么 只有0會(huì)被視作是False,其他所有數(shù)值都是True :
Python中用==判斷相等,表示大于,=表示大于等于, 表示小于,=表示小于等于,!=表示不等。
我們可以用and和or拼裝各個(gè)邏輯運(yùn)算:
注意not,and,or之間的優(yōu)先級(jí),其中not and or。如果分不清楚的話,可以用括號(hào)強(qiáng)行改變運(yùn)行順序。
關(guān)于list的判斷,我們常用的判斷有兩種,一種是剛才介紹的==,還有一種是is。我們有時(shí)候也會(huì)簡(jiǎn)單實(shí)用is來(lái)判斷,那么這兩者有什么區(qū)別呢?我們來(lái)看下面的例子:
Python是全引用的語(yǔ)言,其中的對(duì)象都使用引用來(lái)表示。is判斷的就是 兩個(gè)引用是否指向同一個(gè)對(duì)象 ,而==則是判斷兩個(gè)引用指向的具體內(nèi)容是否相等。舉個(gè)例子,如果我們把引用比喻成地址的話,is就是判斷兩個(gè)變量的是否指向同一個(gè)地址,比如說(shuō)都是沿河?xùn)|路XX號(hào)。而==則是判斷這兩個(gè)地址的收件人是否都叫張三。
顯然,住在同一個(gè)地址的人一定都叫張三,但是住在不同地址的兩個(gè)人也可以都叫張三,也可以叫不同的名字。所以如果a is b,那么a == b一定成立,反之則不然。
Python當(dāng)中對(duì)字符串的限制比較松, 雙引號(hào)和單引號(hào)都可以表示字符串 ,看個(gè)人喜好使用單引號(hào)或者是雙引號(hào)。我個(gè)人比較喜歡單引號(hào),因?yàn)閷?xiě)起來(lái)方便。
字符串也支持+操作,表示兩個(gè)字符串相連。除此之外,我們把兩個(gè)字符串寫(xiě)在一起,即使沒(méi)有+,Python也會(huì)為我們拼接:
我們可以使用[]來(lái)查找字符串當(dāng)中某個(gè)位置的字符,用 len 來(lái)計(jì)算字符串的長(zhǎng)度。
我們可以在字符串前面 加上f表示格式操作 ,并且在格式操作當(dāng)中也支持運(yùn)算,比如可以嵌套上len函數(shù)等。不過(guò)要注意,只有Python3.6以上的版本支持f操作。
最后是None的判斷,在Python當(dāng)中None也是一個(gè)對(duì)象, 所有為None的變量都會(huì)指向這個(gè)對(duì)象 。根據(jù)我們前面所說(shuō)的,既然所有的None都指向同一個(gè)地址,我們需要判斷一個(gè)變量是否是None的時(shí)候,可以使用is來(lái)進(jìn)行判斷,當(dāng)然用==也是可以的,不過(guò)我們通常使用is。
理解了None之后,我們?cè)倩氐街敖榻B過(guò)的bool()函數(shù),它的用途其實(shí)就是判斷值是否是空。所有類型的 默認(rèn)空值會(huì)被返回False ,否則都是True。比如0,"",[], {}, ()等。
除了上面這些值以外的所有值傳入都會(huì)得到True。
Python當(dāng)中的標(biāo)準(zhǔn)輸入輸出是 input和print 。
print會(huì)輸出一個(gè)字符串,如果傳入的不是字符串會(huì)自動(dòng)調(diào)用__str__方法轉(zhuǎn)成字符串進(jìn)行輸出。 默認(rèn)輸出會(huì)自動(dòng)換行 ,如果想要以不同的字符結(jié)尾代替換行,可以傳入end參數(shù):
使用input時(shí),Python會(huì)在命令行接收一行字符串作為輸入??梢栽趇nput當(dāng)中傳入字符串,會(huì)被當(dāng)成提示輸出:
Python支持 三元表達(dá)式 ,但是語(yǔ)法和C++不同,使用if else結(jié)構(gòu),寫(xiě)成:
上段代碼等價(jià)于:
Python中用[]表示空的list,我們也可以直接在其中填充元素進(jìn)行初始化:
使用append和pop可以在list的末尾插入或者刪除元素:
list可以通過(guò)[]加上下標(biāo)訪問(wèn)指定位置的元素,如果是負(fù)數(shù),則表示 倒序訪問(wèn) 。-1表示最后一個(gè)元素,-2表示倒數(shù)第二個(gè),以此類推。如果訪問(wèn)的元素超過(guò)數(shù)組長(zhǎng)度,則會(huì)出發(fā) IndexError 的錯(cuò)誤。
list支持切片操作,所謂的切片則是從原list當(dāng)中 拷貝 出指定的一段。我們用start: end的格式來(lái)獲取切片,注意,這是一個(gè) 左閉右開(kāi)區(qū)間 。如果留空表示全部獲取,我們也可以額外再加入一個(gè)參數(shù)表示步長(zhǎng),比如[1:5:2]表示從1號(hào)位置開(kāi)始,步長(zhǎng)為2獲取元素。得到的結(jié)果為[1, 3]。如果步長(zhǎng)設(shè)置成-1則代表反向遍歷。
如果我們要指定一段區(qū)間倒序,則前面的start和end也需要反過(guò)來(lái),例如我想要獲取[3: 6]區(qū)間的倒序,應(yīng)該寫(xiě)成[6:3:-1]。
只寫(xiě)一個(gè):,表示全部拷貝,如果用is判斷拷貝前后的list會(huì)得到False??梢允褂胐el刪除指定位置的元素,或者可以使用remove方法。
insert方法可以 指定位置插入元素 ,index方法可以查詢某個(gè)元素第一次出現(xiàn)的下標(biāo)。
list可以進(jìn)行加法運(yùn)算,兩個(gè)list相加表示list當(dāng)中的元素合并。 等價(jià)于使用extend 方法:
我們想要判斷元素是否在list中出現(xiàn),可以使用 in關(guān)鍵字 ,通過(guò)使用len計(jì)算list的長(zhǎng)度:
tuple和list非常接近,tuple通過(guò)()初始化。和list不同, tuple是不可變對(duì)象 。也就是說(shuō)tuple一旦生成不可以改變。如果我們修改tuple,會(huì)引發(fā)TypeError異常。
由于小括號(hào)是有改變優(yōu)先級(jí)的含義,所以我們定義單個(gè)元素的tuple, 末尾必須加上逗號(hào) ,否則會(huì)被當(dāng)成是單個(gè)元素:
tuple支持list當(dāng)中絕大部分操作:
我們可以用多個(gè)變量來(lái)解壓一個(gè)tuple:
解釋一下這行代碼:
我們?cè)赽的前面加上了星號(hào), 表示這是一個(gè)list 。所以Python會(huì)在將其他變量對(duì)應(yīng)上值的情況下,將剩下的元素都賦值給b。
補(bǔ)充一點(diǎn),tuple本身雖然是不可變的,但是 tuple當(dāng)中的可變?cè)厥强梢愿淖兊?。比如我們有這樣一個(gè)tuple:
我們雖然不能往a當(dāng)中添加或者刪除元素,但是a當(dāng)中含有一個(gè)list,我們可以改變這個(gè)list類型的元素,這并不會(huì)觸發(fā)tuple的異常:
dict也是Python當(dāng)中經(jīng)常使用的容器,它等價(jià)于C++當(dāng)中的map,即 存儲(chǔ)key和value的鍵值對(duì) 。我們用{}表示一個(gè)dict,用:分隔key和value。
對(duì) 。我們用{}表示一個(gè)dict,用:分隔key和value。
dict的key必須為不可變對(duì)象,所以 list、set和dict不可以作為另一個(gè)dict的key ,否則會(huì)拋出異常:
我們同樣用[]查找dict當(dāng)中的元素,我們傳入key,獲得value,等價(jià)于get方法。
我們可以call dict當(dāng)中的keys和values方法,獲取dict當(dāng)中的所有key和value的集合,會(huì)得到一個(gè)list。在Python3.7以下版本當(dāng)中,返回的結(jié)果的順序可能和插入順序不同,在Python3.7及以上版本中,Python會(huì)保證返回的順序和插入順序一致:
我們也可以用in判斷一個(gè)key是否在dict當(dāng)中,注意只能判斷key。
如果使用[]查找不存在的key,會(huì)引發(fā)KeyError的異常。如果使用 get方法則不會(huì)引起異常,只會(huì)得到一個(gè)None :
setdefault方法可以 為不存在的key 插入一個(gè)value,如果key已經(jīng)存在,則不會(huì)覆蓋它:
我們可以使用update方法用另外一個(gè)dict來(lái)更新當(dāng)前dict,比如a.update(b)。對(duì)于a和b交集的key會(huì)被b覆蓋,a當(dāng)中不存在的key會(huì)被插入進(jìn)來(lái):
我們一樣可以使用del刪除dict當(dāng)中的元素,同樣只能傳入key。
Python3.5以上的版本支持使用**來(lái)解壓一個(gè)dict:
set是用來(lái)存儲(chǔ) 不重復(fù)元素 的容器,當(dāng)中的元素都是不同的,相同的元素會(huì)被刪除。我們可以通過(guò)set(),或者通過(guò){}來(lái)進(jìn)行初始化。注意當(dāng)我們使用{}的時(shí)候,必須要傳入數(shù)據(jù),否則Python會(huì)將它和dict弄混。
set當(dāng)中的元素也必須是不可變對(duì)象,因此list不能傳入set。
可以調(diào)用add方法為set插入元素:
set還可以被認(rèn)為是集合,所以它還支持一些集合交叉并補(bǔ)的操作。
set還支持 超集和子集的判斷 ,我們可以用大于等于和小于等于號(hào)判斷一個(gè)set是不是另一個(gè)的超集或子集:
和dict一樣,我們可以使用in判斷元素在不在set當(dāng)中。用copy可以拷貝一個(gè)set。
Python當(dāng)中的判斷語(yǔ)句非常簡(jiǎn)單,并且Python不支持switch,所以即使是多個(gè)條件,我們也只能 羅列if-else 。
我們可以用in來(lái)循環(huán)迭代一個(gè)list當(dāng)中的內(nèi)容,這也是Python當(dāng)中基本的循環(huán)方式。
如果我們要循環(huán)一個(gè)范圍,可以使用range。range加上一個(gè)參數(shù)表示從0開(kāi)始的序列,比如range(10),表示[0, 10)區(qū)間內(nèi)的所有整數(shù):
如果我們傳入兩個(gè)參數(shù),則 代表迭代區(qū)間的首尾 。
如果我們傳入第三個(gè)元素,表示每次 循環(huán)變量自增的步長(zhǎng) 。
如果使用enumerate函數(shù),可以 同時(shí)迭代一個(gè)list的下標(biāo)和元素 :
while循環(huán)和C++類似,當(dāng)條件為T(mén)rue時(shí)執(zhí)行,為false時(shí)退出。并且判斷條件不需要加上括號(hào):
Python當(dāng)中使用 try和except捕獲異常 ,我們可以在except后面限制異常的類型。如果有多個(gè)類型可以寫(xiě)多個(gè)except,還可以使用else語(yǔ)句表示其他所有的類型。finally語(yǔ)句內(nèi)的語(yǔ)法 無(wú)論是否會(huì)觸發(fā)異常都必定執(zhí)行 :
在Python當(dāng)中我們經(jīng)常會(huì)使用資源,最常見(jiàn)的就是open打開(kāi)一個(gè)文件。我們 打開(kāi)了文件句柄就一定要關(guān)閉 ,但是如果我們手動(dòng)來(lái)編碼,經(jīng)常會(huì)忘記執(zhí)行close操作。并且如果文件異常,還會(huì)觸發(fā)異常。這個(gè)時(shí)候我們可以使用with語(yǔ)句來(lái)代替這部分處理,使用with會(huì) 自動(dòng)在with塊執(zhí)行結(jié)束或者是觸發(fā)異常時(shí)關(guān)閉打開(kāi)的資源 。
以下是with的幾種用法和功能:
凡是可以使用in語(yǔ)句來(lái)迭代的對(duì)象都叫做 可迭代對(duì)象 ,它和迭代器不是一個(gè)含義。這里只有可迭代對(duì)象的介紹,想要了解迭代器的具體內(nèi)容,請(qǐng)移步傳送門(mén):
Python——五分鐘帶你弄懂迭代器與生成器,夯實(shí)代碼能力
當(dāng)我們調(diào)用dict當(dāng)中的keys方法的時(shí)候,返回的結(jié)果就是一個(gè)可迭代對(duì)象。
我們 不能使用下標(biāo)來(lái)訪問(wèn) 可迭代對(duì)象,但我們可以用iter將它轉(zhuǎn)化成迭代器,使用next關(guān)鍵字來(lái)獲取下一個(gè)元素。也可以將它轉(zhuǎn)化成list類型,變成一個(gè)list。
使用def關(guān)鍵字來(lái)定義函數(shù),我們?cè)趥鲄⒌臅r(shí)候如果指定函數(shù)內(nèi)的參數(shù)名, 可以不按照函數(shù)定義的順序 傳參:
可以在參數(shù)名之前加上*表示任意長(zhǎng)度的參數(shù),參數(shù)會(huì)被轉(zhuǎn)化成list:
也可以指定任意長(zhǎng)度的關(guān)鍵字參數(shù),在參數(shù)前加上**表示接受一個(gè)dict:
當(dāng)然我們也可以兩個(gè)都用上,這樣可以接受任何參數(shù):
傳入?yún)?shù)的時(shí)候我們也可以使用*和**來(lái)解壓list或者是dict:
Python中的參數(shù) 可以返回多個(gè)值 :
函數(shù)內(nèi)部定義的變量即使和全局變量重名,也 不會(huì)覆蓋全局變量的值 。想要在函數(shù)內(nèi)部使用全局變量,需要加上 global 關(guān)鍵字,表示這是一個(gè)全局變量:
Python支持 函數(shù)式編程 ,我們可以在一個(gè)函數(shù)內(nèi)部返回一個(gè)函數(shù):
Python中可以使用lambda表示 匿名函數(shù) ,使用:作為分隔,:前面表示匿名函數(shù)的參數(shù),:后面的是函數(shù)的返回值:
我們還可以將函數(shù)作為參數(shù)使用map和filter,實(shí)現(xiàn)元素的批量處理和過(guò)濾。關(guān)于Python中map、reduce和filter的使用,具體可以查看之前的文章:
五分鐘帶你了解map、reduce和filter
我們還可以結(jié)合循環(huán)和判斷語(yǔ)來(lái)給list或者是dict進(jìn)行初始化:
使用 import語(yǔ)句引入一個(gè)Python模塊 ,我們可以用.來(lái)訪問(wèn)模塊中的函數(shù)或者是類。
我們也可以使用from import的語(yǔ)句,單獨(dú)引入模塊內(nèi)的函數(shù)或者是類,而不再需要寫(xiě)出完整路徑。使用from import *可以引入模塊內(nèi)所有內(nèi)容(不推薦這么干)
可以使用as給模塊內(nèi)的方法或者類起別名:
我們可以使用dir查看我們用的模塊的路徑:
這么做的原因是如果我們當(dāng)前的路徑下也有一個(gè)叫做math的Python文件,那么 會(huì)覆蓋系統(tǒng)自帶的math的模塊 。這是尤其需要注意的,不小心會(huì)導(dǎo)致很多奇怪的bug。
我們來(lái)看一個(gè)完整的類,相關(guān)的介紹都在注釋當(dāng)中
以上內(nèi)容的詳細(xì)介紹之前也有過(guò)相關(guān)文章,可以查看:
Python—— slots ,property和對(duì)象命名規(guī)范
下面我們來(lái)看看Python當(dāng)中類的使用:
這里解釋一下,實(shí)例和對(duì)象可以理解成一個(gè)概念,實(shí)例的英文是instance,對(duì)象的英文是object。都是指類經(jīng)過(guò)實(shí)例化之后得到的對(duì)象。
繼承可以讓子類 繼承父類的變量以及方法 ,并且我們還可以在子類當(dāng)中指定一些屬于自己的特性,并且還可以重寫(xiě)父類的一些方法。一般我們會(huì)將不同的類放在不同的文件當(dāng)中,使用import引入,一樣可以實(shí)現(xiàn)繼承。
我們創(chuàng)建一個(gè)蝙蝠類:
我們?cè)賱?chuàng)建一個(gè)蝙蝠俠的類,同時(shí)繼承Superhero和Bat:
執(zhí)行這個(gè)類:
我們可以通過(guò)yield關(guān)鍵字創(chuàng)建一個(gè)生成器,每次我們調(diào)用的時(shí)候執(zhí)行到y(tǒng)ield關(guān)鍵字處則停止。下次再次調(diào)用則還是從yield處開(kāi)始往下執(zhí)行:
除了yield之外,我們還可以使用()小括號(hào)來(lái)生成一個(gè)生成器:
關(guān)于生成器和迭代器更多的內(nèi)容,可以查看下面這篇文章:
五分鐘帶你弄懂迭代器與生成器,夯實(shí)代碼能力
我們引入functools當(dāng)中的wraps之后,可以創(chuàng)建一個(gè)裝飾器。裝飾器可以在不修改函數(shù)內(nèi)部代碼的前提下,在外面包裝一層其他的邏輯:
裝飾器之前也有專門(mén)的文章詳細(xì)介紹,可以移步下面的傳送門(mén):
一文搞定Python裝飾器,看完面試不再慌
不知道有多少小伙伴可以看到結(jié)束,原作者的確非常厲害,把Python的基本操作基本上都囊括在里面了。如果都能讀懂并且理解的話,那么Python這門(mén)語(yǔ)言就算是入門(mén)了。
如果你之前就有其他語(yǔ)言的語(yǔ)言基礎(chǔ),我想本文讀完應(yīng)該不用30分鐘。當(dāng)然在30分鐘內(nèi)學(xué)會(huì)一門(mén)語(yǔ)言是不可能的,也不是我所提倡的。但至少通過(guò)本文我們可以做到熟悉Python的語(yǔ)法,知道大概有哪些操作,剩下的就要我們親自去寫(xiě)代碼的時(shí)候去體會(huì)和運(yùn)用了。
根據(jù)我的經(jīng)驗(yàn),在學(xué)習(xí)一門(mén)新語(yǔ)言的前期,不停地查閱資料是免不了的。希望本文可以作為你在使用Python時(shí)候的查閱文檔。
最后,我這里有各種免費(fèi)的編程類資料,有需要的及時(shí)私聊我,回復(fù)"學(xué)習(xí)",分享給大家,正在發(fā)放中............
用python的sendkeys直接模擬鍵盤(pán),用ctype擴(kuò)展來(lái)點(diǎn)鼠標(biāo)。你需要做的就是用python打開(kāi)瀏覽器,然后輸入網(wǎng)站,在找到按鈕的坐標(biāo)(固定到程序里),然后點(diǎn)擊就行了。不過(guò)簡(jiǎn)單的可以,復(fù)雜點(diǎn)的就要考慮很多問(wèn)題了,程序截圖如下:
新聞名稱:python函數(shù)句柄,matlab句柄函數(shù)
標(biāo)題鏈接:http://www.ekvhdxd.cn/article12/heggdc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機(jī)、動(dòng)態(tài)網(wǎng)站、全網(wǎng)營(yíng)銷推廣、關(guān)鍵詞優(yōu)化、商城網(wǎng)站、響應(yīng)式網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)