簡介
有興趣可以看看: 解釋性語言+動態類型語言+強型別語言
互動模式:(主要拿來實驗,可以試試 ipython)
複製代碼 代碼如下:
$python
>>> print 'hello world'
指令碼
複製代碼 代碼如下:
#!/usr/bin/env python
print 'hello world'
環境:
建議python2.7 + easy_install + pip + virtualenv + ipython
縮排
Python 函數沒有明顯的 begin 和 end,沒有標明函數的開始和結束的花括弧。唯一的分隔字元是一個冒號 (:),接著代碼本身是縮排的。
例子:
複製代碼 代碼如下:
#函數
def func(value):
print value #縮排
if value == 1:
value += 1
elif value == 2:
pass
else:
value += 10
標識符
變數是標識符的例子。 標識符 是用來標識 某樣東西 的名字。在命名標識符的時候,你要遵循這些規則:
1.python中的標識符是區分大小寫。
2.標示符以字母或底線開頭,可包括字母,底線和數字,大小寫敏感
3.以底線開頭的標識符是有特殊意義的。
以單底線開頭(_foo)的代表不能直接存取的類屬性,需通過類提供的介面進行訪問,不能用“from xxx import *”而匯入;
以雙底線開頭的(__foo)代表類的私人成員;
以雙底線開頭和結尾的(foo)代表python裡特殊方法專用的標識,如init()代表類的建構函式。
4.標識符不能是保留字
複製代碼 代碼如下:
and elif global or yield
assert else if pass
break except import print
class exec in raise
continue finally is return
def for lambda try
del from not while
變數
指派陳述式
1、指派陳述式建立對象引用值
2、變數名在首次賦值時會被建立
3、變數名在引用前必須先賦值,不能引用未聲明賦值的變數
賦值方式
簡單賦值
Variable(變數)=Value(值)
複製代碼 代碼如下:
s = ‘spam'
多變數賦值
python中原始的元組和列表指派陳述式形成,最後已被通用化,以接受右側可以是是任何類型的序列,只要長度相等即可。注意,長度一定相等
Variable1,variable2,...=Value1,Value2,...
複製代碼 代碼如下:
s,h = ‘a','b' 元組賦值,位置性 【常用】
[s,h] =[‘a','b'] 列表賦值,位置性
a,b,c,d = ‘spam' 序列賦值,通用性
a,*b = ‘spam' 拓展序列解包(python3)
多目標賦值
複製代碼 代碼如下:
a=b=variable
s = h = ‘spam' 多目標賦值
注意:多個變數記憶體中指向同一對象,對於可變類型需要,修改一個會對其他造成影響
自變賦值
複製代碼 代碼如下:
如+=,-=,*=等。
在自變賦值中,python僅計算一次,而普通寫法需計算兩次;
自變賦值會修改原始對象,而不是建立一個新對象。
複製代碼 代碼如下:
s +=42 增強賦值
x += y
優點:
複製代碼 代碼如下:
左側只需計算一次,最佳化技術自動原處修改,更快
l +=[] 原處修改
l = l+[] 複製,產生新的對象
運算子
一個運算式可以分解為運算子和運算元
運算子 的功能是完成某件事,它們由如+這樣的符號或者其他特定的關鍵字表示
運算子需要資料來進行運算,這樣的資料被稱為 運算元
運算子優先順序列表(從最高到最低)
複製代碼 代碼如下:
運算子 描述
'expr' 字串轉換
{key:expr,...} 字典
[expr1,expr2...] 列表
(expr1,expr2,...) 元組
function(expr,...) 函數調用
x[index:index] 切片
x[index] 下標索引取值
x.attribute 屬性引用
~x 按位取反
+x,-x 正,負
x**y 冪
x*y,x/y,x%y 乘,除,模數
x+y,x-y 加,減
x<>y 移位
x&y 按位與
x^y 按位異或
x|y 按位或
x=y,x>y 比較
x is y,x is not y 等同測試
x in y,x not in y 成員判斷
not x 邏輯否
x and y 邏輯與
x or y 邏輯或
lambda arg,...:expr Lambda匿名函數
結合規律
運算子通常由左向右結合,即具有相同優先順序的運算子按照從左向右的順序計算
計算順序
預設地,運算子優先順序表決定了哪個運算子在別的運算子之前計算。然而,如果你想要改變它們的計算順序,你得使用圓括弧。好的做法:預設對複雜的運算加括弧,而不是依賴於預設結合和計算順序
真值
真值測試
1、任何非零數字或非Null 物件都為真
2、數字零,Null 物件以及特殊對象None都為假
3、比較和相等測試都會遞迴地運用到資料結構中
4、比較和相等測試會返回True或False
真值表
複製代碼 代碼如下:
對象/常量 值
"" 假
"string" 真
0 假
2>=1 真
-2<=-1 真
()空元組 假
[]空列表 假
{}空字典 假
None 假
布林運算式
三種布林運算式運算子
複製代碼 代碼如下:
x and y
x or y
not x
比較
數字通過相對大小進行比較
字串時按照字典順序的,一個字元一個字元比較
列表和元組從左至右對每部分的內容進行比較
字典通過排序後的索引值列表進行比較
數字混合類型比較在python3是錯誤的,但是python2.6支援,固定但任意的定序
布爾數
有兩個永遠不改變的值True,False
布爾是整型的子類,但不能被再繼承
沒有nonzero()方法的對象的預設值是True
對於值為0的任何數字或空集,值False
在數學運算中,Bollean值的True和False分別對應於1和0
基本控制流程
if
基本的條件測試語句,用來判斷可能遇到的不同情況,並針對不同的情況進行操作
基本形式
複製代碼 代碼如下:
if <條件>:
<語句>
elif <條件>:
<語句>
else:
<語句>
注意
python根據縮排判斷, elif和else部分是可選的
例子:
複製代碼 代碼如下:
a = 1
b = 2
c = 3;d=4 #兩個放一句用分號隔開,不過建議分行
if a < b and c < d:
print("branch a")
elif a == b:
print("branch b")
else:
print("branch c")
switch
python 本身沒有 switch 語句,若需要,用if/elif/else實現完成同樣的工作,某些情況可以考慮用字典
也可以用dict的形式
if/else三元運算子
複製代碼 代碼如下:
A = ((X and Y) or Z)
A = Y if X else Z
例: a = ‘t' if x else ‘a'
[code]
for
基本文法
迴圈控制語句,可以用於迴圈遍曆某一序列
else塊可選,在迴圈終止的時候執行,若是break終止迴圈,else不執行
格式:
[code]
for <物件變數> in <對象集合>:
if<條件>:
break
if<條件>:
continue
<其他語句>
else:
<其他語句>
注意:
1.對象集合可以是列表,字典以及元組等
2.for..in迴圈對於任何序列都適用
3.for遍曆一個字典時,遍曆的是字典的鍵
複製代碼 代碼如下:
rang & xrange
可以通過range()函數產生一個整數列表,完成計數迴圈
複製代碼 代碼如下:
range([start,] stop[, step])
start選擇性參數,起始數
stop終止數,若為x,產生從0-(x-1)的整數列表
step選擇性參數,步長,未寫預設為1
range(1,5) 包含序列為 [1,2,3,4]
xrange和range區別
(python3.x的可無視)
在Range的方法中,它會產生一個list的對象,但是在XRange中,它產生的卻是一個xrange的對象,當返回的東西不是很大的時候,或者在一個迴圈裡,基本上都是從頭查到底的情況下,這兩個方法的效率差不多。但是,當返回的東西很大,或者迴圈中常常會被Break出來的話,還是建議使用XRange,這樣既省空間,又會提高效率。
複製代碼 代碼如下:
>>> print range(1, 5)
[1, 2, 3, 4]
>>> print xrange(1, 5)
xrange(1, 5)
在上面語句中,range返回了一個普通List,而xrange返回了一個特定的xrange類型的對象。由於 xrange 方法也建立整數 list(其使用相同參數),所以它與 range 方法非常相似。但是,xrange 方法僅在需要時才在 list 中建立整數。當需要迭代大量整數時,xrange 方法更適用,因為它不會建立極大的 list,那樣會消耗大量電腦記憶體。
while
與if語句類似,含一個條件測試語句,迴圈,允許重複執行一個語句塊。
可選else語句塊,同for的else塊。
格式:
複製代碼 代碼如下:
while <條件>:
if <條件>:
break
if <條件>:
continue
<其他語句>
else:
<語句>
說明:
while迴圈條件變為False的時候,else塊才被執行
若是使用break結束迴圈,while可選的else塊不執行
python沒有do while或do until迴圈語句
break & continue & pass
break,終止迴圈語句,停止迴圈,若是for/while迴圈中終止,其else不執行
continue,結束當前,進入下一輪迴圈 - 跳到最近所在迴圈的開頭處(來到迴圈首行)
pass 什麼事也不做,只是空佔位語句,它用於那些文法上必須要有什麼語句,但程式什麼也不做的場合
迴圈else塊 :只有迴圈正常離開時才會執行,即
如果你從for或while迴圈中break終止 ,任何對應的迴圈else塊將不執行。記住,break語句也可以在for迴圈中使用
其他
編寫迴圈的技巧:
在迭代過程中修改迭代序列不安全(只有在使用鏈表這樣的可變序列時才會有這樣的情況)。如果你想要修改你迭代的序列(例如,複製選擇項),你可以迭代它的複本。使用切割標識就可以很方便的做到這一點
>>>複製代碼 代碼如下:
for x in a[:]: # make a slice copy of the entire list
... if len(x) > 6: a.insert(0, x)
在字典中迴圈時,關鍵字和對應的值可以使用 iteritems() 方法同時解讀出來
複製代碼 代碼如下:
>>> knights = {'gallahad': 'the pure', 'robin': 'the brave'}
>>> for k, v in knights.iteritems():
... print k, v
...
gallahad the pure
robin the brave
在序列中迴圈時,索引位置和對應值可以使用 enumerate() 函數同時得到。
複製代碼 代碼如下:
>>> for i, v in enumerate(['tic', 'tac', 'toe']):
... print i, v