九九热最新网址,777奇米四色米奇影院在线播放,国产精品18久久久久久久久久,中文有码视频,亚洲一区在线免费观看,国产91精品在线,婷婷丁香六月天

Python 基礎(chǔ)語法

上傳人:仙*** 文檔編號:89738842 上傳時(shí)間:2022-05-13 格式:DOC 頁數(shù):26 大?。?0KB
收藏 版權(quán)申訴 舉報(bào) 下載
Python 基礎(chǔ)語法_第1頁
第1頁 / 共26頁
Python 基礎(chǔ)語法_第2頁
第2頁 / 共26頁
Python 基礎(chǔ)語法_第3頁
第3頁 / 共26頁

下載文檔到電腦,查找使用更方便

10 積分

下載資源

還剩頁未讀,繼續(xù)閱讀

資源描述:

《Python 基礎(chǔ)語法》由會員分享,可在線閱讀,更多相關(guān)《Python 基礎(chǔ)語法(26頁珍藏版)》請?jiān)谘b配圖網(wǎng)上搜索。

1、word Python的特點(diǎn)   1. 簡單     Python是一種代表簡單思想的語言。   2. 易學(xué)     Python有極其簡單的語法。   3. 免費(fèi)、開源     Python是FLOSS〔自由/開放源碼軟件〕之一。   4. 高層語言     使用Python編寫程序時(shí)無需考慮如何管理程序使用的內(nèi)存一類的底層細(xì)節(jié)。   5. 可移植性     Python已被移植到很多平臺,這些平臺包括Linux、Windows、FreeBSD、Macintosh、Solaris、OS/2、Amiga、AROS、AS/400、

2、   BeOS、OS/390、z/OS、Palm OS、QNX、VMS、Psion、A RISC OS、VxWorks、PlayStation、Sharp Zaurus、   Windows CE甚至還有PocketPC。   6. 解釋性     可以直接從源代碼運(yùn)行。在計(jì)算機(jī)內(nèi)部,python解釋器把源代碼轉(zhuǎn)換為字節(jié)碼的中間形式,然后再把它翻譯成計(jì)算機(jī)使用的機(jī)器語言。   7. 面向?qū)ο?     Python既支持面向過程編程也支持面向?qū)ο缶幊獭?   8. 可擴(kuò)展性     局部程序可以使用其他語言編寫,如c/c++。   9. 可嵌入型

3、     可以把Python嵌入到c/c++程序中,從而提供腳本功能。   10. 豐富的庫     Python標(biāo)準(zhǔn)庫確實(shí)很龐大。它可以幫助你處理各種工作,包括正如此表達(dá)式、文檔生成、單元測試、線程、數(shù)據(jù)庫、網(wǎng)頁瀏覽器、CGI、FTP、   電子、XML、XML-RPC、HTML、WAV文件、密碼系統(tǒng)、GUI〔圖形用戶界面〕、Tk和其他與系統(tǒng)有關(guān)的操作。 ---------------分割線------------------------以下是Python的根本語法----------------------------------------------

4、----------- 一、根本概念   1. python中數(shù)有四種類型:整數(shù)、長整數(shù)、浮點(diǎn)數(shù)和復(fù)數(shù)。 整數(shù), 如 1 長整數(shù) 是比擬大的整數(shù) 浮點(diǎn)數(shù) 如 1.23、3E-2   2. 字符串〔字符的序列〕 python中單引號和雙引號使用完全一樣。 使用三引號('''或""")可以指定一個(gè)多行字符串。 轉(zhuǎn)義符 '\' 自然字符串, 通過在字符串前加r或R。 如 r"this is a line with \n" 如此\n會顯示,并不是換行。 python允許處理unicode字符串,加前綴u或U, 如 u"this is an unicode st

5、ring"。 字符串是不可變的。 按字面意義級聯(lián)字符串,如"this " "is " "string"會被自動轉(zhuǎn)換為this is string。   3. 標(biāo)識符的命名 第一個(gè)字符必須是字母表中字母或下劃線'_'。 標(biāo)識符的其他的局部有字母、數(shù)字和下劃線組成。 標(biāo)識符對大小寫敏感。   4. 對象     python程序中用到的任何“東西〞都成為“對象〞。   5. 邏輯行和物理行     物理行是我們在編寫程序時(shí)看到的,邏輯行如此是python看到的。     python中分號;標(biāo)識一個(gè)邏輯行的完畢,但是實(shí)際中一般每個(gè)物理行只寫一個(gè)邏輯行,可以

6、防止使用分號。     多個(gè)物理行中可以寫一個(gè)邏輯行,如下: s = "peter is \ writing this article"     上面\的使用被稱為‘明確的行連接’, 又如: print \ "peter"   6. 縮進(jìn)     空白在python是非常重要的,行首的空白是最重要的,又稱為縮進(jìn)。行首的空白〔空格和制表符〕用來決定邏輯行的縮進(jìn)層次,從而決定語句   分組。這意味著同一層次的語句必須有一樣的縮進(jìn),每一組這樣的語句稱為一個(gè)塊。   注意:不要混合使用空格和制表符來縮進(jìn),因?yàn)樵诳缭讲煌钠脚_時(shí)無法正常工作。 二、運(yùn)算符

7、與表達(dá)式   1. 運(yùn)算符與其用法 運(yùn)算符名稱說明例子 +加兩個(gè)對象相加3 + 5得到8。'a' + 'b'得到'ab'。 -減得到負(fù)數(shù)或是一個(gè)數(shù)減去另一個(gè)數(shù)-5.2得到一個(gè)負(fù)數(shù)。50 - 24得到26。 *乘兩個(gè)數(shù)相乘或是返回一個(gè)被重復(fù)假如干次的字符串2 * 3得到6。'la' * 3得到'lalala'。 **冪 返回x的y次冪 3 ** 4得到81〔即3 * 3 * 3 * 3〕 <<左移把一個(gè)數(shù)的比特向左移一定數(shù)目〔每個(gè)數(shù)在內(nèi)存中都表示為比特或二進(jìn)制數(shù)字,即0和1〕2 << 2得到8?!?按比特表示為10 >>右移把一個(gè)數(shù)的比特向右移一定數(shù)

8、目11 >> 1得到5?!?1按比特表示為1011,向右移動1比特后得到101,即十進(jìn)制的5。 &按位與數(shù)的按位與5 & 3得到1。 |按位或數(shù)的按位或5 | 3得到7。 ^按位異或數(shù)的按位異或5 ^ 3得到6 ~按位翻轉(zhuǎn)x的按位翻轉(zhuǎn)是-(x+1)~5得到6。 <小于返回x是否小于y。所有比擬運(yùn)算符返回1表示真,返回0表示假。這分別與特殊的變量True和False等價(jià)。注意,這些變量名的大寫。5 < 3返回0〔即False〕而3 < 5返回1〔即True〕。比擬可以被任意連接:3 < 5 < 7返回True。 >大于返回x是否大于y5 > 3返回True。如果兩個(gè)操作數(shù)都是數(shù)字,

9、它們首先被轉(zhuǎn)換為一個(gè)共同的類型。否如此,它總是返回False。 <=小于等于返回x是否小于等于yx = 3; y = 6; x <= y返回True。 >=大于等于返回x是否大于等于yx = 4; y = 3; x >= y返回True。 ==等于比擬對象是否相等x = 2; y = 2; x == y返回True。x = 'str'; y = 'stR'; x == y返回False。x = 'str'; y = 'str'; x == y返回True。 !=不等于比擬兩個(gè)對象是否不相等x = 2; y = 3; x != y返回True。 not布爾“非〞如果x為True,返回F

10、alse。如果x為False,它返回True。x = True; not y返回False。 and布爾“與〞如果x為False,x and y返回False,否如此它返回y的計(jì)算值。x = False; y = True; x and y,由于x是False,返回False。在這里,Python不會計(jì)算y,因?yàn)樗肋@個(gè)表達(dá)式的值肯定是False〔因?yàn)閤是False〕。這個(gè)現(xiàn)象稱為短路計(jì)算。 or布爾“或〞如果x是True,它返回True,否如此它返回y的計(jì)算值。x = True; y = False; x or y返回True。短路計(jì)算在這里也適用。   2. 運(yùn)算符優(yōu)先級〔從低到

11、高〕 運(yùn)算符描述 lambdaLambda表達(dá)式 or布爾“或〞 and布爾“與〞 not x布爾“非〞 in,not in成員測試 is,is not同一性測試 <,<=,>,>=,!=,==比擬 |按位或 ^按位異或 &按位與 <<,>>移位 +,-加法與減法 *,/,%乘法、除法與取余 +x,-x正負(fù)號 ~x按位翻轉(zhuǎn) **指數(shù) x[index]下標(biāo) x[index:index]尋址段 f(arguments...)函數(shù)調(diào)用 (experession,...)綁定或元組顯示 [expression,...]列表顯示 {key:datum

12、,...}字典顯示 'expression,...'字符串轉(zhuǎn)換   3. python 控制臺輸出 使用print print "abc"   #打印abc并換行 print "abc%s" % "d"   #打印abcd print "abc%sef%s" % ("d", "g")   #打印abcdefg 三、控制流   1. if 語句 i = 10 n = int(raw_input("enter a number:")) if n == i: print "equal" elif n < i: print "low

13、er" else: print "higher"   2. while語句 while True: pass else: pass #else語句可選,當(dāng)while為False時(shí),else語句被執(zhí)行。 pass是空語句。   3. for 循環(huán) for..in for i in range(0, 5): print i else: pass # 打印0到4   注:當(dāng)for循環(huán)完畢后執(zhí)行else語句;     range(a, b)返回一個(gè)序列,從a開始到b為止,但不包括b,range默認(rèn)步長為1,可以指

14、定步長,range(0,10,2);   4. break語句     終止循環(huán)語句,如果從for或while中終止,任何對應(yīng)循環(huán)的else將不執(zhí)行。   5. continue語句     continue語句用來調(diào)過當(dāng)前循環(huán)的剩余語句,然后繼續(xù)下一輪循環(huán)。 四、函數(shù)   函數(shù)通過def定義。def關(guān)鍵字后跟函數(shù)的標(biāo)識符名稱,然后跟一對圓括號,括號之內(nèi)可以包含一些變量名,該行以冒號結(jié)尾;接下來是一塊語句,即函數(shù)體。 def sumOf(a, b): return a + b   1. 函數(shù)形參     函數(shù)中的參數(shù)名稱為‘形參’,調(diào)

15、用函數(shù)時(shí)傳遞的值為‘實(shí)參’   2. 局部變量     在函數(shù)內(nèi)定義的變量與函數(shù)外具有一樣名稱的其他變量沒有任何關(guān)系,即變量名稱對于函數(shù)來說是局部的。這稱為變量的作用域。     global語句, 為定義在函數(shù)外的變量賦值時(shí)使用global語句。 def func(): global x print "x is ", x x = 1 x = 3 func() print x #3 #1   3. 默認(rèn)參數(shù)     通過使用默認(rèn)參數(shù)可以使函數(shù)的一些參數(shù)是‘可選的’。 def say(msg, tim

16、es = 1): print msg * times say("peter") say("peter", 3)     注意:只有在形參表末尾的那些參數(shù)可以有默認(rèn)參數(shù)值,即不能在聲明函數(shù)形參的時(shí)候,先聲明有默認(rèn)值的形參而后聲明沒有默認(rèn)值的形參,只是因?yàn)橘x給形參的值是根據(jù)位置而賦值的。   4. 關(guān)鍵參數(shù)     如果某個(gè)函數(shù)有很多參數(shù),而現(xiàn)在只想指定其中的局部,那么可以通過命名為這些參數(shù)賦值〔稱為‘關(guān)鍵參數(shù)’〕。     優(yōu)點(diǎn):不必?fù)?dān)心參數(shù)的順序,使函數(shù)變的更加簡單;假設(shè)其他參數(shù)都有默認(rèn)值,可以只給我們想要的那些參數(shù)賦值。 def func(a

17、, b=2, c=3): print "a is %s, b is %s, c is %s" % (a, b, c) func(1) #a is 1, b is 2, c is 3 func(1, 5) #a is 1, b is 5, c is 3 func(1, c = 10) #a is 1, b is 2, c is 10 func(c = 20, a = 30) #a is 30, b is 2, c is 20   5. return 語句     return語句用來從一個(gè)函數(shù)返回,即跳出函數(shù)??蓮暮瘮?shù)返回一個(gè)值。     沒有返回值的re

18、turn語句等價(jià)于return None。None表示沒有任何東西的特殊類型。   6. DocStrings (文檔字符串) def func(): '''This is self-defined function Do nothing''' pass #This is self-defined function # #Do nothing 五、模塊   模塊就是一個(gè)包含了所有你定義的函數(shù)和變量的文件,模塊必須以.py為擴(kuò)展名。模塊可以從其他程序中‘輸入’(import)以便利用它的功能。   在python程序中

19、導(dǎo)入其他模塊使用'import', 所導(dǎo)入的模塊必須在sys.path所列的目錄中,因?yàn)閟ys.path第一個(gè)字符串是空串''即當(dāng)前目錄,所以程序中可導(dǎo)入當(dāng)前目錄的模塊。     導(dǎo)入模塊比擬費(fèi)時(shí),python做了優(yōu)化,以便導(dǎo)入模塊更快些。一種方法是創(chuàng)建字節(jié)編譯的文件,這些文件以.pyc為擴(kuò)展名。     pyc是一種二進(jìn)制文件,是py文件經(jīng)編譯后產(chǎn)生的一種byte code,而且是跨平臺的〔平臺無關(guān)〕字節(jié)碼,是有python虛擬機(jī)執(zhí)行的,類似于   java或.net虛擬機(jī)的概念。pyc的內(nèi)容,是跟python的版本相關(guān)的,不同版本編譯后的pyc文件是不同的。

20、   2. from .. import     如果想直接使用其他模塊的變量或其他,而不加'模塊名+.'前綴,可以使用from .. import。     例如想直接使用sys的argv,from sys import argv 或 from sys import *   3. 模塊的__name__     每個(gè)模塊都有一個(gè)名稱,py文件對應(yīng)模塊名默認(rèn)為py文件名,也可在py文件中為__name__賦值;如果是__name__,說明這個(gè)模塊被用戶   單獨(dú)運(yùn)行。   4. dir()函數(shù)     dir(sys)返回sys模塊的名稱列表;如果不提

21、供參數(shù),即dir(),如此返回當(dāng)前模塊中定義名稱列表。     del -> 刪除一個(gè)變量/名稱,del之后,該變量就不能再使用。 六、數(shù)據(jù)結(jié)構(gòu)   python有三種內(nèi)建的數(shù)據(jù)結(jié)構(gòu):列表、元組和字典。   1. 列表     list是處理一組有序項(xiàng)目的數(shù)據(jù)結(jié)構(gòu),列表是可變的數(shù)據(jù)結(jié)構(gòu)。列表的項(xiàng)目包含在方括號[]中,eg: [1, 2, 3], 空列表[]。判斷列表中是否包含某項(xiàng)可以使用in, 比如 l = [1, 2, 3]; print 1 in l; #True;支持索引和切片操作;索引時(shí)假如超出X圍,如此IndexError;使用函數(shù)len()查看長度;使

22、用del可以刪除列表中的項(xiàng),eg: del l[0] # 如果超出X圍,如此IndexError     list函數(shù)如下:     append〔value〕  ---向列表尾添加項(xiàng)value l = [1, 2, 2] l.append(3) #[1, 2, 2, 3]     count(value)  ---返回列表中值為value的項(xiàng)的個(gè)數(shù) l = [1, 2, 2] print l.count(2) # 2     extend(list2)  ---向列表尾添加列表list2 l = [1, 2, 2] l1 = [10, 20] l.e

23、xtend(l1) print l #[1, 2, 2, 10, 20]     index(value, [start, [stop]])  ---返回列表中第一個(gè)出現(xiàn)的值為value的索引,如果沒有,如此異常 ValueError l = [1, 2, 2] a = 4 try: print l.index(a) except ValueError, ve: print "there is no %d in list" % a     insert(i, value)  ---向列表i位置插入項(xiàng)vlaue,如果沒有i,如此添加到列表尾部

24、l = [1, 2, 2] l.insert(1, 100) print l #[1, 100, 2, 2] l.insert(100, 1000) print l #[1, 100, 2, 2, 1000]     pop([i])  ---返回i位置項(xiàng),并從列表中刪除;如果不提供參數(shù),如此刪除最后一個(gè)項(xiàng);如果提供,但是i超出索引X圍,如此異常IndexError l = [0, 1, 2, 3, 4, 5] print l.pop() # 5 print l #[0, 1, 2, 3, 4] print l.pop(1) #1 print l

25、 #[0, 2, 3, 4] try: l.pop(100) except IndexError, ie: print "index out of range"     remove(value)  ---刪除列表中第一次出現(xiàn)的value,如果列表中沒有vlaue,如此異常ValueError l = [1, 2, 3, 1, 2, 3] l.remove(2) print l #[1, 3, 1, 2, 3] try: l.remove(10) except ValueError, ve: print "ther

26、e is no 10 in list"     reverse()  ---列表反轉(zhuǎn) l = [1, 2, 3] l.reverse() print l #[3, 2, 1]     sort(cmp=None, key=None, reverse=False)  ---列表排序 【Python Library Reference】 cmp:cmp specifies a custom parison function of two arguments (iterable elements) which should return a negative, zero o

27、r positive number depending on whether the first argument is considered smaller than, equal to, or larger than the second argument: "cmp=lambda x,y: cmp(x.lower(), y.lower())" key:key specifies a function of one argument that is used to extract a parison key from each list element: "key=str.lowe

28、r" reverse:reverse is a boolean value. If set to True, then the list elements are sorted as if each parison were reversed.In general, the key and reverse conversion processes are much faster than specifying an equivalent cmp function. This is because cmp is called multiple times for each list ele

29、ment while key and reverse touch each element only once. l5 = [10, 5, 20, 1, 30] l5.sort() print l5 #[1, 5, 10, 20, 30] l6 = ["bcd", "abc", "cde", "bbb"] l6.sort(cmp = lambda s1, s2: cmp(s1[0],s2[1])) print l6 #['abc', 'bbb', 'bcd', 'cde'] l7 = ["bcd", "abc", "cde", "bbb", "faf"] l7.so

30、rt(key = lambda s: s[1]) print l7 #['faf', 'abc', 'bbb', 'bcd', 'cde']  2. 元組     tuple和list十分相似,但是tuple是不可變的,即不能修改tuple,元組通過圓括號中用逗號分割的項(xiàng)定義;支持索引和切片操作;可以使用 in   查看一個(gè)元素是否在tuple中。空元組();只含有一個(gè)元素的元組("a",) #需要加個(gè)逗號     優(yōu)點(diǎn):tuple比list速度快;對不需要修改的數(shù)據(jù)進(jìn)展‘寫保護(hù)’,可以是代碼更安全     tuple與list可以相互轉(zhuǎn)換,使用內(nèi)置的函數(shù)lis

31、t()和tuple()。 l = [1, 2, 3] print l # [1, 2, 3] t = tuple(l) print t # (1, 2, 3) l1 = list(t) print l1 #[1, 2, 3]     元組最通常的用法是用在打印語句,如下例: name = "Peter Zhang" age = 25 print "Name: %s; Age: %d" % (name, age) # Name: Peter Zhang; Age: 25     函數(shù)如下:     count(value)  ---返回元組中

32、值為value的元素的個(gè)數(shù) t = (1, 2, 3, 1, 2, 3) print t.count(2) # 2     index(value, [start, [stop]])  ---返回列表中第一個(gè)出現(xiàn)的值為value的索引,如果沒有,如此異常 ValueError t = (1, 2, 3, 1, 2, 3) print t.index(3) # 2 try: print t.index(4) except ValueError, ve: print "there is no 4 in tuple" # there is no

33、 4 in tuple   3. 字典     字典由鍵值對組成,鍵必須是唯一的;eg: d = {key1:value1, key2:value2};空字典用{}表示;字典中的鍵值對是沒有順序的,如果想要   一個(gè)特定的順序,那么使用前需要對它們排序;d[key] = value,如果字典中已有key,如此為其賦值為value,否如此添加新的鍵值對key/value;使   用del d[key] 可以刪除鍵值對;判斷字典中是否有某鍵,可以使用in 或 not in; d = {} d["1"] = "one" d["2"] = "two" d["3

34、"] = "three" del d["3"] for key, value in d.items(): print "%s --> %s" % (key, value) #1 --> one #2 --> two     dict函數(shù)如下:     clear()  ---刪除字典中所有元素 d1 = {"1":"one", "2":"two"} d1.clear() print d1 # {}     copy()  ---返回字典的一個(gè)副本(淺復(fù)制) d1 = {"1":"one", "2":"two"} d2 = d1.co

35、py() print d2 #{'1': 'one', '2': 'two'}     dict.fromkeys(seq,val=None) ---創(chuàng)建并返回一個(gè)新字典,以序列seq中元素做字典的鍵,val為字典所有鍵對應(yīng)的初始值(默認(rèn)為None) l = [1, 2, 3] t = (1, 2, 3) d3 = {}.fromkeys(l) print d3 #{1: None, 2: None, 3: None} d4 = {}.fromkeys(t, "default") print d4 #{1: 'default', 2: 'default',

36、3: 'default'}     get(key,[default])  ---返回字典dict中鍵key對應(yīng)值,如果字典中不存在此鍵,如此返回default 的值(default默認(rèn)值為None) d5 = {1:"one", 2:"two", 3:"three"} print d5.get(1) #one print d5.get(5) #None print d5.get(5, "test") #test     has_key(key)  ---判斷字典中是否有鍵key d6 = {1:"one", 2:"two", 3:"three"} prin

37、t d6.has_key(1) #True print d6.has_key(5) #False     items()  ---返回一個(gè)包含字典中(鍵, 值)對元組的列表 d7 = {1:"one", 2:"two", 3:"three"} for item in d7.items(): print item #(1, 'one') #(2, 'two') #(3, 'three') for key, value in d7.items(): print "%s -- %s" % (key, value) #1 -- one #2

38、-- two #3 -- three     keys()  ---返回一個(gè)包含字典中所有鍵的列表 d8 = {1:"one", 2:"two", 3:"three"} for key in d8.keys(): print key #1 #2 #3     values()  ---返回一個(gè)包含字典中所有值的列表 d8 = {1:"one", 2:"two", 3:"three"} for value in d8.values(): print value #one #two #three     pop(k

39、ey, [default])  ---假如字典中key鍵存在,刪除并返回dict[key],假如不存在,且未給出default值,引發(fā)KeyError異常 d9 = {1:"one", 2:"two", 3:"three"} print d9.pop(1) #one print d9 #{2: 'two', 3: 'three'} print d9.pop(5, None) #None try: d9.pop(5) # raise KeyError except KeyError, ke: print "KeyError:", ke #KeyErro

40、r:5     popitem()  ---刪除任意鍵值對,并返回該鍵值對,如果字典為空,如此產(chǎn)生異常KeyError d10 = {1:"one", 2:"two", 3:"three"} print d10.popitem() #(1, 'one') print d10 #{2: 'two', 3: 'three'}     setdefault(key,[default])  ---假如字典中有key,如此返回vlaue值,假如沒有key,如此加上該key,值為default,默認(rèn)None d = {1:"one", 2:"two", 3:"three

41、"} print d.setdefault(1) #one print d.setdefault(5) #None print d #{1: 'one', 2: 'two', 3: 'three', 5: None} print d.setdefault(6, "six") #six print d #{1: 'one', 2: 'two', 3: 'three', 5: None, 6: 'six'}     update(dict2)  ---把dict2的元素參加到dict中去,鍵字重復(fù)時(shí)會覆蓋dict中的鍵值 d = {1:"one", 2:"two"

42、, 3:"three"} d2 = {1:"first", 4:"forth"} d.update(d2) print d #{1: 'first', 2: 'two', 3: 'three', 4: 'forth'}     viewitems()  ---返回一個(gè)view對象,〔key, value〕pair的列表,類似于視圖。優(yōu)點(diǎn)是,如果字典發(fā)生變化,view會同步發(fā)生變化。在   迭代過程中,字典不允許改變,否如此會報(bào)異常 d = {1:"one", 2:"two", 3:"three"} for key, value in d.viewitems():

43、 print "%s - %s" % (key, value) #1 - one #2 - two #3 - three     viewkeys()  ---返回一個(gè)view對象,key的列表 d = {1:"one", 2:"two", 3:"three"} for key in d.viewkeys(): print key #1 #2 #3     viewvalues()  ---返回一個(gè)view對象,value的列表 d = {1:"one", 2:"two", 3:"three"} for value in d.viewvalues

44、(): print value #one #two #three   4. 序列     序列類型是指容器內(nèi)的元素從0開始的索引順序訪問,一次可以訪問一個(gè)或者多個(gè)元素;列表、元組和字符串都是序列;序列的兩個(gè)主要特點(diǎn)是   索引操作符和切片操作符;索引可以得到特定元素;切片可以得到局部序列; 1 numbers = ["zero", "one", "two", "three", "four"] 2 3 print numbers[1] # one 4 print numbers[-1] # four 5 #print numbers[5

45、] # raise IndexError 6 7 print numbers[:] # ['zero', 'one', 'two', 'three', 'four'] 8 print numbers[3:] # ['three', 'four'] 9 print numbers[:2] # ['zero', 'one'] 10 print numbers[2:4] # ['two', 'three'] 11 print numbers[1:-1] # ['one', 'two', 'three']     切片操作符中的第一個(gè)數(shù)〔冒號之前〕表示切片開始的位置,第二

46、個(gè)數(shù)〔冒號之后〕表示切片到哪里完畢。 如果不指定第一個(gè)數(shù),Python就從   序列首開始。如果沒有指定第二個(gè)數(shù),如此Python會停止在序列尾。 注意,返回的序列從開始位置 開始 ,剛好在完畢位置之前 完畢。即開始位置是   包含在序列切片中的,而完畢位置被排斥在切片外。 可以用負(fù)數(shù)做切片。負(fù)數(shù)用在從序列尾開始計(jì)算的位置。   5. 綁定     當(dāng)創(chuàng)建一個(gè)對象并給它賦一個(gè)變量的時(shí)候,這個(gè)變量僅僅“指向〞那個(gè)對象,而不是表示這個(gè)對象本身! 也就是說,變量名指向計(jì)算機(jī)中存儲那個(gè)   對象的內(nèi)存,這被稱作名稱到對象的綁定。     如果要復(fù)制一個(gè)列表或者類似的序列

47、或者其他復(fù)雜的對象〔不是如整數(shù)那樣的簡單對象〕,那么必須使用切片操作符來取得拷貝。 七、面向?qū)ο缶幊?   python支持面向?qū)ο缶幊?;類和對象是面向?qū)ο缶幊痰膬蓚€(gè)主要方面,類創(chuàng)建一個(gè)新的類型,對象是這個(gè)類的實(shí)例。   對象可以使用普通的屬于對象的變量存儲數(shù)據(jù),屬于對象或類的變量被稱為域;對象也可以使用屬于類的函數(shù),這樣的函數(shù)稱為類的方法;域和方法可以合稱為類的屬性。   域有兩種類型--屬于實(shí)例的或?qū)儆陬惐旧?;它們分別被稱為實(shí)例變量和類變量。   類使用關(guān)鍵字class創(chuàng)建,類的域和方法被列在一個(gè)縮進(jìn)塊中。   類的方法必須有一個(gè)額外的第一個(gè)參數(shù),但是在調(diào)用時(shí)

48、不為這個(gè)參數(shù)賦值,這個(gè)特殊變量指對象本身,按照慣例它的名稱是self,類似C#中的this。 class Animal: pass #empty block   __init__方法  在類的一個(gè)對象被創(chuàng)建時(shí)調(diào)用該方法;相當(dāng)于c++中的構(gòu)造函數(shù)。   __del__方法  在類的對象被銷毀時(shí)調(diào)用該方法;相當(dāng)于c++中的析構(gòu)函數(shù)。在使用del刪除一個(gè)對象時(shí)也就調(diào)用__del__方法。   Python中所有的類成員(包括數(shù)據(jù)成員)都是public的;只有一個(gè)例外,如果使用的數(shù)據(jù)成員以雙下劃線為前綴,如此為私有變量。 class Person: C

49、ount = 0 def __init__(self, name, age): Person.Count += 1 self.name = name self.__age = age p = Person("peter", 25) p1 = Person("john", 20) print Person.Count #2 print p.name #peter print p.__age #AttributeError: Person instance has no attribute '__age'   

50、繼承:為了使用繼承,基類的名稱作為一個(gè)元組跟在類名稱的后面;python支持多重繼承。下面是一個(gè)關(guān)于繼承的例子: 1 class SchoolMember: 2 '''Represent any school member.''' 3 def __init__(self, name, age): 4 self.name = name 5 self.age = age 6 print "Initializing a school member." 7 8 def tell(s

51、elf): 9 '''Tell my details''' 10 print "Name: %s, Age: %s, " % (self.name, self.age), 11 12 class Teacher(SchoolMember): 13 '''Represent a teacher.''' 14 def __init__(self, name, age, salary): 15 SchoolMember.__init__(self, name, age) 16 self.salary

52、= salary 17 print "Initializing a teacher" 18 19 def tell(self): 20 SchoolMember.tell(self) 22 23 class Student(SchoolMember): 24 '''Represent a student.''' 25 def __init__(self, name, age, marks): 26 SchoolMember.__init__(self, name, age) 27

53、 self.marks = marks 28 print "Initializing a student" 29 30 def tell(self): 31 SchoolMember.tell(self) 33 37 38 t = Teacher("Mr. Li", 30, 9000) 39 s = Student("Peter", 25, 90) 40 41 members = [t, s] 42 43 for m in members: 44 m.tell()   程序輸出如下:

54、 Represent any school member. Represent a teacher. Represent a student. Initializing a school member. Initializing a teacher Initializing a school member. Initializing a student Name: Mr. Li, Age: 30, Salary: 9000 Name: Peter, Age: 25, Marks: 90 八、輸入/輸出   程序與用戶的交互需要使用輸入/輸出,主要包括控制臺和

55、文件;對于控制臺可以使用raw_input和print,也可使用str類。raw_input(xxx)輸入xxx然后讀取用戶的輸入并返回。   1. 文件輸入/輸出     可以使用file類打開一個(gè)文件,使用file的read、readline和write來恰當(dāng)?shù)淖x寫文件。對文件讀寫能力取決于打開文件時(shí)使用的模式,常用模式   有讀模式("r")、寫模式("w")、追加模式("a"),文件操作之后需要調(diào)用close方法來關(guān)閉文件。 1 test = '''\ 2 This is a program about file I/O. 3 4 Autho

56、r: Peter Zhange 5 Date: 2011/12/25 6 ''' 7 8 f = file("test.txt", "w") # open for writing, the file will be created if the file doesn't exist 9 f.write(test) # write text to file 10 f.close() # close the file 11 12 f = file("test.txt") # if no mode is specified, the default mode is re

57、adonly. 13 14 while True: 15 line = f.readline() 16 if len(line) == 0: # zero length indicates the EOF of the file 17 break 18 print line, 19 20 f.close()   2. 存儲器     python提供一個(gè)標(biāo)準(zhǔn)的模塊,成為pickle,使用它可以在一個(gè)文件中存儲任何python對象,之后可以完整的取出來,這被稱為持久地存儲對象;還有另外一個(gè)模塊成為cPickle,它的功能和

58、pickle完全一樣,只不過它是用c寫的,要比pickle速度快(大約快1000倍)。 import cPickle datafile = "data.data" namelist = ["peter", "john", "king"] f = file(datafile, "w") cPickle.dump(namelist, f) f.close() del namelist f = file(datafile) storednamelist = cPickle.load(f) print storednamelist #['peter

59、', 'john', 'king'] 九、異常   當(dāng)程序中出現(xiàn)某些異常的狀況時(shí),異常就發(fā)生了。python中可以使用try ... except 處理。 try: print 1/0 except ZeroDivisionError, e: print e except: print "error or exception occurred." #integer division or modulo by zero   可以讓try ... except 關(guān)聯(lián)上一個(gè)else,當(dāng)沒有異常時(shí)如此執(zhí)行else。   我們可以

60、定義自己的異常類,需要繼承Error或Exception。 class ShortInputException(Exception): '''A user-defined exception class''' def __init__(self, length, atleast): Exception.__init__(self) self.length = length self.atleast = atleast try: s = raw_input("enter someting-->")

61、 if len(s) < 3: raise ShortInputException(len(s), 3) except EOFError: print "why you input an EOF?" except ShortInputException, ex: print "The lenght of input is %d, was expecting at the least %d" % (ex.length, ex.atleast) else: print "no exception" #The lenght of in

62、put is 1, was expecting at the least 3   try...finally try: f = file("test.txt") while True: line = f.readline() if len(line) == 0: break time.sleep(2) print line, finally: f.close() print "Cleaning up..." 十、Python標(biāo)準(zhǔn)庫

63、   Python標(biāo)準(zhǔn)庫是隨Pthon附帶安裝的,包含了大量極其有用的模塊。   1. sys模塊  sys模塊包含系統(tǒng)對應(yīng)的功能 sys.argv  ---包含命令行參數(shù),第一個(gè)參數(shù)是py的文件名 sys.platform  ---返回平臺類型 sys.exit([status])  ---退出程序,可選的status(X圍:0-127):0表示正常退出,其他表示不正常,可拋異常事件供捕獲 sys.modules  ---This is a dictionary that maps module names to modules which have alread

64、y been loaded sys.stdin,sys.stdout,sys.stderr  ---包含與標(biāo)準(zhǔn)I/O 流對應(yīng)的流對象 s = sys.stdin.readline() sys.stdout.write(s)   2. os模塊  該模塊包含普遍的操作系統(tǒng)功能 os.name字符串指示你正在使用的平臺。比如對于Windows,它是'nt',而對于Linux/Unix用戶,它是'posix' os.getcwd()函數(shù)得到當(dāng)前工作目錄,即當(dāng)前Python腳本工作的目錄路徑 os.getenv()和os.putenv()函數(shù)分別用來讀取和設(shè)置環(huán)境變量 os.l

65、istdir()返回指定目錄下的所有文件和目錄名 os.remove()函數(shù)用來刪除一個(gè)文件 os.system()函數(shù)用來運(yùn)行shell命令 os.linesep字符串給出當(dāng)前平臺使用的行終止符。例如,Windows使用'\r\n',Linux使用'\n'而Mac使用'\r' os.sep 操作系統(tǒng)特定的路徑分割符 os.path.split()函數(shù)返回一個(gè)路徑的目錄名和文件名 os.path.isfile()和os.path.isdir()函數(shù)分別檢驗(yàn)給出的路徑是一個(gè)文件還是目錄 os.path.existe()函數(shù)用來檢驗(yàn)給出的路徑是否真地存在 十一、其他   1.

66、 一些特殊的方法 名稱說明 __init__(self,...)這個(gè)方法在新建對象恰好要被返回使用之前被調(diào)用。 __del__(self)恰好在對象要被刪除之前調(diào)用。 __str__(self)在我們對對象使用print語句或是使用str()的時(shí)候調(diào)用。 __lt__(self,other)當(dāng)使用 小于 運(yùn)算符〔<〕的時(shí)候調(diào)用。類似地,對于所有的運(yùn)算符〔+,>等等〕都有特殊的方法。 __getitem__(self,key)使用x[key]索引操作符的時(shí)候調(diào)用。 __len__(self)對序列對象使用內(nèi)建的len()函數(shù)的時(shí)候調(diào)用。   下面的類中定義了上表中的方法: class Array: __list = [] def __init__(self): print "constructor" def __del__(self): print "destructor" def __str__(self): return "this self-def

展開閱讀全文
溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號:ICP2024067431-1 川公網(wǎng)安備51140202000466號


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺,本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請立即通知裝配圖網(wǎng),我們立即給予刪除!