1、基本概念
1.1 四種類型
python中數有四種類型:整數、長整數、浮點數和複數。
python中數有四種類型:整數、長整數、浮點數和複數。
- 整數, 如 1
- 長整數 是比較大的整數
- 浮點數 如 1.23、3E-2
- 複數 如 1 + 2j、 1.1 + 2.2j
1.2 字符串
字符串(字符的序列)
- python中單引號和雙引號使用完全相同。
- 使用三引號('''或""")可以指定一個多行字符串。
- 轉義符 ''
- 自然字符串, 通過在字符串前加r或R。 如 r"this is a line with \n" 則\n會顯示,並不是換行。
- python允許處理unicode字符串,加前綴u或U, 如 u"this is an unicode string"。
- 字符串是不可變的。
- 按字面意義級聯字符串,如"this " "is " "string"會被自動轉換爲this is string。
1.3 標識符的命名 標識符的命名
- 第一個字符必須是字母表中字母或下劃線'_'。
- 標識符的其他的部分有字母、數字和下劃線組成。
- 標識符對大小寫敏感。
ps:在看的過程中如果有遇到任何問題可以到我的學習交流羣【Python學習交流】:點擊此處一起交流學習。
1.4 對象
python程序中用到的任何“東西”都成爲“對象”。
1.5 邏輯行和物理行
- 物理行:就是程序員所寫代碼的所在行。
- 邏輯行:是指源代碼經過預編譯後,代碼所在的那一行。
Python假定每個物理行都對應着一個邏輯行。例如:print( "Hello World" ) 就是一個物理行,Python希望每行只有一個語句,因爲這樣看起來更加易讀。
如果你想要在一個物理行中使用多於一個邏輯行,那麼你需要使用分號(; )來特別地標明這種用法。分號表示一個邏輯行/語句的結束。
例如:
count = 5print ( "count" )
與下面的語句等同:
count = 5;print ( "count" );
當然也可以寫成下面這種:
count = 5 ; print ( "count" );
甚至可以寫成這樣:
count = 5 ; print ( "count" )
我們使用\的換行
print \
("Runsen")
1.6 縮進
空白在python是非常重要的,行首的空白是最重要的,又稱爲縮進。行首的空白(空格和製表符)用來決定邏輯行的縮進層次,從而決定語句。
相關視頻推薦:
python學會這些面試兼職接單都不是問題!_嗶哩嗶哩 (゜-゜)つロ 乾杯~-bilibiliwww.bilibili.com
大學生如何利用python在網上接單,兼職也能月入過萬_嗶哩嗶哩 (゜-゜)つロ 乾杯~-bilibiliwww.bilibili.com python零基礎爬蟲玩轉股市,躺着賺錢的副業(爬蟲和數據分析可視化)_嗶哩嗶哩 (゜-゜)つロ 乾杯~-bilibiliwww.bilibili.com[圖片上傳失敗...(image-2d5ef5-1604912330951)]2、運算符與表達式
2.1 運算符與其用法
2.2 運算符優先級
.運算符優先級(從低到高)
2.3 輸出
python 控制檯輸出 使用print
print ("abc" ) #打印abc並換行print ("abc%s" % "d" ) #打印abcdprint ("abc%sef%s" % ("d", "g") ) #打印abcdefg
3、控制流
3.1 if 語句
= 10n = int(input("enter a number:"))if n == i:
print( "equal")elif n < i:
print( "lower")else: print ("higher")
3.2 while語句
while True: passelse: pass#else語句可選,當while爲False時,else語句被執行。 pass是空語句。
for 循環 for..in
for i in range(0, 5): print (i)else: pass# 打印0到4
注:當for循環結束後執行else語句;range(a, b)返回一個序列,從a開始到b爲止,但不包括b,range默認步長爲1,可以指定步長,range(0,10,2);
3.3 break語句
終止循環語句,如果從for或while中終止,任何對應循環的else將不執行。
3.4 continue語句
continue語句用來調過當前循環的剩餘語句,然後繼續下一輪循環。
下面就是 break 和 continue 主要的 區別:
break:跳出整個循環
continue:跳出本次循環,繼續執行下一次循環
希望大家牢記。
4、函數
函數通過def定義。def關鍵字後跟函數的標識符名稱,然後跟一對圓括號,括號之內可以包含一些變量名,該行以冒號結尾;接下來是一塊語句,即函數體。
def sumOf(a, b):
return a + b
4.1 函數形參
函數中的參數名稱爲‘形參’,調用函數時傳遞的值爲‘實參’
4.2 局部變量
在函數內定義的變量與函數外具有相同名稱的其他變量沒有任何關係,即變量名稱對於函數來說是局部的。這稱爲變量的作用域。
global語句, 爲定義在函數外的變量賦值時使用global語句。
def func():
global x
print( "x is ", x)
x = 1x = 3func()
print(x)#3#1
4.3 默認參數
通過使用默認參數可以使函數的一些參數是‘可選的’。
def say(msg, times = 1):
print(msg * times)
say("Runsen")
say("Runsen", 3)
注意:只有在形參表末尾的那些參數可以有默認參數值,即不能在聲明函數形參的時候,先聲明有默認值的形參而後聲明沒有默認值的形參,只是因爲賦給形參的值是根據位置而賦值的。
4.4 關鍵參數
如果某個函數有很多參數,而現在只想指定其中的部分,那麼可以通過命名爲這些參數賦值(稱爲‘關鍵參數’)。 優點:不必擔心參數的順序,使函數變的更加簡單;假設其他參數都有默認值,可以只給我們想要的那些參數賦值。
def func(a, 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 3func(1, 5) #a is 1, b is 5, c is 3func(1, c = 10) #a is 1, b is 2, c is 10func(c = 20, a = 30) #a is 30, b is 2, c is 20
4.5 return 語句
return語句用來從一個函數返回,即跳出函數。可從函數返回一個值。 沒有返回值的return語句等價於return None。None表示沒有任何東西的特殊類型。
4.6 文檔字符串
doc (文檔字符串)
def func():
'''This is self-defined function
Do nothing
'''
passprint(func.__doc__)#This is self-defined function##Do nothing
5、模塊
模塊就是一個包含了所有你定義的函數和變量的文件,模塊必須以.py爲擴展名。模塊可以從其他程序中‘輸入’(import)以便利用它的功能。
在python程序中導入其他模塊使用'import', 所導入的模塊必須在sys.path所列的目錄中,因爲sys.path第一個字符串是空串''即當前目錄,所以程序中可導入當前目錄的模塊。
5.1 字節編譯的.pyc文件
導入模塊比較費時,python做了優化,以便導入模塊更快些。一種方法是創建字節編譯的文件,這些文件以.pyc爲擴展名。
pyc是一種二進制文件,是py文件經編譯後產生的一種byte code,而且是跨平臺的(平臺無關)字節碼,是有python虛擬機執行的,類似於
java或.net虛擬機的概念。pyc的內容,是跟python的版本相關的,不同版本編譯後的pyc文件是不同的。
5.2 from .. import
如果想直接使用其他模塊的變量或其他,而不加'模塊名+.'前綴,可以使用from .. import。
例如想直接使用sys的argv,from sys import argv 或 from sys import *
5.3 模塊的name
每個模塊都有一個名稱,py文件對應模塊名默認爲py文件名,也可在py文件中爲name賦值;如果是name,說明這個模塊被用戶
(4) dir()函數
dir(sys)返回sys模塊的名稱列表;如果不提供參數,即dir(),則返回當前模塊中定義名稱列表。
(5) del
del -> 刪除一個變量/名稱,del之後,該變量就不能再使用。
6、數據結構
python有三種內建的數據結構:列表、元組和字典。
6.1 列表
list是處理一組有序項目的數據結構,列表是可變的數據結構。列表的項目包含在方括號[]中,
eg: [1, 2, 3], 空列表[]。判斷列表中是否包含某項可以使用in,
比如 l = [1, 2, 3]; print 1 in l; #True;
支持索引和切片操作;索引時若超出範圍,則IndexError;
使用函數len()查看長度;使用del可以刪除列表中的項,eg: del l[0] # 如果超出範圍,則IndexError
list函數如下:
append(value) ---向列表尾添加項value
l = [1, 2, 2]
l.append(3) #[1, 2, 2, 3]count(value) ---返回列表中值爲value的項的個數
l = [1, 2, 2]
print( l.count(2)) # 2extend(list2) ---向列表尾添加列表list2
l = [1, 2, 2]
l1 = [10, 20]
l.extend(l1)print (l ) #[1, 2, 2, 10, 20]index(value, [start, [stop]]) ---返回列表中第一個出現的值爲value的索引,如果沒有,則異常 ValueError
l = [1, 2, 2]
a = 4try:
print( l.index(a))except ValueError, ve:
print( "there is no %d in list" % a
insert(i, value)) ---向列表i位置插入項vlaue,如果沒有i,則添加到列表尾部
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位置項,並從列表中刪除;如果不提供參數,則刪除最後一個項;如果提供,但是i超出索引範圍,則異常IndexError
l = [0, 1, 2, 3, 4, 5]
print( l.pop()) # 5print( l) #[0, 1, 2, 3, 4]print( l.pop(1)) #1print( l) #[0, 2, 3, 4]try:
l.pop(100)except IndexError, ie:
print( "index out of range")
remove(value) ---刪除列表中第一次出現的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 ("there is no 10 in list")
reverse() ---列表反轉
l = [1, 2, 3]
l.reverse()print (l) #[3, 2, 1]sort(cmp=None, key=None, reverse=False) ---列表排序
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.sort(key = lambda s: s[1])print (l7) #['faf', 'abc', 'bbb', 'bcd', 'cde']