在Python中,能夠直接處理的數據類型有以下幾種:
print語句也可以跟上多個字符串,用逗號“,”隔開,就可以連成一串輸出:
print 'The quick brown fox', 'jumps over', 'the lazy dog'print會依次打印每個字符串,遇到逗號“,”會輸出一個空格,因此,輸出的字符串是這樣拼起來的:The quick brown fox jumps over the lazy dogprint也可以打印整數,或者計算結果:print 300 運行結果300
或 print 100 + 200任何時候,我們都可以給程序加上注釋。注釋是用來說明代碼的,給自己或別人看,而程序運行的時候,Python解釋器會直接忽略掉注釋,所以,有沒有注釋不影響程序的執行結果,但是影響到別人能不能看懂你的代碼。Python的注釋以 # 開頭,后面的文字直到行尾都算注釋如:# 注釋..或 hello world # 這也是注釋
3、Python的注釋
4、Python之變量
在Python中,變量的概念基本上和初中代數的方程變量是一致的。只是在計算機程序中,變量不僅可以是數字,還可以是任意數據類型。在Python程序中,變量是用一個變量名表示,變量名必須是大小寫英文、數字和下劃線(_)的組合,且不能用數字開頭,比如:a = 1。 變量a是一個整數。t_007 = 'T007' 。變量t_007是一個字符串。在Python中,等號=是賦值語句,可以把任意數據類型賦值給變量,同一個變量可以反復賦值,而且可以是不同類型的變量,例如:a = 123 # a是整數a = 'imooc' # a變為字符串這種變量本身類型不固定的語言稱之為動態語言,與之對應的是靜態語言。靜態語言在定義變量時必須指定變量類型,如果賦值的時候類型不匹配,就會報錯。例如java是靜態語言,賦值語句如下(// 表示注釋):int a = 123; // a是整數類型變量a = "mooc"; // 錯誤:不能把字符串賦給整型變量和靜態語言相比,動態語言更靈活,就是這個原因。請不要把賦值語句的等號等同于數學的等號。比如下面的代碼:x = 10x = x + 2如果從數學上理解x = x + 2那無論如何是不成立的,在程序中,賦值語句先計算右側的表達式x + 2,得到結果12,再賦給變量x。由于x之前的值是10,重新賦值后,x的值變成12。最后,理解變量在計算機內存中的表示也非常重要。當我們寫:a = 'ABC'時,Python解釋器干了兩件事情:1. 在內存中創建了一個'ABC'的字符串;2. 在內存中創建了一個名為a的變量,并把它指向'ABC'。也可以把一個變量a賦值給另一個變量b,這個操作實際上是把變量b指向變量a所指向的數據,例如下面的代碼:a = 'ABC'b = aa = 'XYZ'print b最后一行打印出變量b的內容到底是'ABC'呢還是'XYZ'?如果從數學意義上理解,就會錯誤地得出b和a相同,也應該是'XYZ',但實際上b的值是'ABC',讓我們一行一行地執行代碼,就可以看到到底發生了什么事:執行a = 'ABC',解釋器創建了字符串 'ABC'和變量 a,并把a指向 'ABC':執行b = a,解釋器創建了變量 b,并把b指向 a 指向的字符串'ABC':執行a = 'XYZ',解釋器創建了字符串'XYZ',并把a的指向改為'XYZ',但b并沒有更改:所以,最后打印變量b的結果自然是'ABC'了。
5、Python中定義字符串
前面我們講解了什么是字符串。字符串可以用''或者""括起來表示。如果字符串本身包含'怎么辦?比如我們要表示字符串 I'm OK ,這時,可以用" "括起來表示:"I'm OK"類似的,如果字符串包含",我們就可以用' '括起來表示:'Learn "Python" in imooc'如果字符串既包含'又包含"怎么辦?這個時候,就需要對字符串的某些特殊字符進行“轉義”,Python字符串用/進行轉義。要表示字符串 Bob said "I'm OK".由于 ' 和 " 會引起歧義,因此,我們在它前面插入一個/表示這是一個普通字符,不代表字符串的起始,因此,這個字符串又可以表示為'Bob said /"I/'m OK/".'注意:轉義字符 / 不計入字符串的內容中。常用的轉義字符還有:/n 表示換行/t 表示一個制表符// 表示 / 字符本身Python中raw字符串與多行字符串如果一個字符串包含很多需要轉義的字符,對每一個字符都進行轉義會很麻煩。為了避免這種情況,我們可以在字符串前面加個前綴 r ,表示這是一個 raw 字符串,里面的字符就不需要轉義了。例如:r'/(~_~)/ /(~_~)/'但是r'...'表示法不能表示多行字符串,也不能表示包含'和 "的字符串(為什么?)如果要表示多行字符串,可以用'''...'''表示:'''Line 1Line 2Line 3'''上面這個字符串的表示方法和下面的是完全一樣的:'Line 1/nLine 2/nLine 3'還可以在多行字符串前面添加 r ,把這個多行字符串也變成一個raw字符串:
r'''Python is created by "Guido".It is free and easy to learn.Let's start learn Python in imooc!'''
6、Python中Unicode字符串
字符串還有一個編碼問題。如果要表示中文,顯然一個字節是不夠的,至少需要兩個字節,而且還不能和ASCII編碼沖突,所以,中國制定了GB2312編碼,用來把中文編進去。為了統一所有文字的編碼,Unicode應運而生。Unicode把所有語言都統一到一套編碼里,這樣就不會再有亂碼問題了。Unicode通常用兩個字節表示一個字符,原有的英文編碼從單字節變成雙字節,只需要把高字節全部填為0就可以。# -*- coding: utf-8 -*-或 #coding= utf-8 都可以識別python語言中的中文目的是告訴Python解釋器,用UTF-8編碼讀取源代碼。然后用Notepad++ 另存為... 并選擇UTF-8格式保存。
7、Python中整數和浮點數
Python支持對整數和浮點數直接進行四則混合運算,為什么要區分整數運算和浮點數運算呢?這是因為整數運算的結果永遠是精確的,而浮點數運算的結果不一定精確,因為計算機內存再大,也無法精確表示出無限循環小數,比如 0.1 換成二進制表示就是無限循環小數。如,我們要計算 11 / 4 的精確結果,按照“整數和浮點數混合運算的結果是浮點數”的法則,把兩個數中的一個變成浮點數再運算就沒問題了:11.0 / 4 #輸出2.75
8、Python中布爾類型
我們已經了解了Python支持布爾類型的數據,布爾類型只有True和False兩種值,但是布爾類型有以下幾種運算:與運算:只有兩個布爾值都為 True 時,計算結果才為 True。True and True # ==> TrueTrue and False # ==> FalseFalse and True # ==> FalseFalse and False # ==> False或運算:只要有一個布爾值為 True,計算結果就是 True。True or True # ==> TrueTrue or False # ==> TrueFalse or True # ==> TrueFalse or False # ==> False非運算:把True變為False,或者把False變為True:not True # ==> Falsenot False # ==> True布爾運算在計算機中用來做條件判斷,根據計算結果為True或者False,計算機可以自動執行不同的后續代碼。 and 和 or 運算的一條重要法則:短路計算。1. 在計算 a and b 時,如果 a 是 False,則根據與運算法則,整個結果必定為 False,因此返回 a;如果 a 是 True,則整個計算結果必定取決與 b,因此返回 b。2. 在計算 a or b 時,如果 a 是 True,則根據或運算法則,整個計算結果必定為 True,因此返回 a;如果 a 是 False,則整個計算結果必定取決于 b,因此返回 b。所以Python解釋器在做布爾運算時,只要能提前確定計算結果,它就不會往后算了,直接返回結果。
新聞熱點
疑難解答