Python-基礎-day2
- 2020 年 2 月 10 日
- 筆記
Python環境的安裝
安裝Python:
windows:
1、下載安裝包 https://www.python.org/downloads/ 2、安裝 默認安裝路徑:C:python27 3、配置環境變數 【右鍵電腦】–》【屬性】–》【高級系統設置】–》【高級】–》【環境變數】–》【在第二個內容框中找到 變數名為Path 的一行,雙擊】 –> 【Python安裝目錄追加到變值值中,用 ; 分割】 如:原來的值;C:python27,切記前面有分號 |
---|
Linux:
無需安裝,原裝Python環境、如果自帶2.6,請更新至2.7
更新Python的方法:
windows:
進行卸載重裝 |
---|
linux:
Linux的yum依賴自帶Python,為防止錯誤,此處更新其實就是再安裝一個Python |
---|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
查看默認Python版本 python -V 1、安裝gcc,用於編譯Python源碼 yum install gcc 2、下載源碼包,https://www.python.org/ftp/python/ 3、解壓並進入源碼文件 4、編譯安裝 ./configure make all make install 5、查看版本 /usr/local/bin/python2.7 -V 6、修改默認Python版本 mv /usr/bin/python /usr/bin/python2.6 ln -s /usr/local/bin/python2.7 /usr/bin/python 7、防止yum執行異常,修改yum使用的Python版本 vi /usr/bin/yum 將頭部 #!/usr/bin/python 修改為 #!/usr/bin/python2.6 |
---|
Python入門咯
首先檢查一下Python版本:

1、讓我們一起來運行第一個Python程式吧
我們現在桌面上的python筆記這個文件夾里創建一個名叫ceshi的以.py結尾的文件

運行這個文件:

windows進入Python命令行


Python內部執行過程如下所示:

2、解釋器
我們剛才運行的ceshi.py這個文件,時明確的指定使用Python解釋器執行的。
如果我們也想和linux一樣類似與執行shell腳本一樣去執行這個ceshi.py需要怎麼做呢,例: ceshi.py,那麼我們應該怎樣才能實現呢,就需要在文件的頭部指定解釋器了
如下:
1 2 |
#! /usr/bin/env python print('hello world') |
---|
在執行時 ./ceshi.py
ps:需要注意的是要給 ceshi.py這個文件授予執行許可權,chmod +755 ceshi.py
3、內容編碼
python解釋器在載入 .py 文件中的程式碼時,會對內容進行編碼(默認ascill)
ASCII(American Standard Code for Information Interchange,美國標準資訊交換程式碼)是基於拉丁字母的一套電腦編碼系統,主要用於顯示現代英語和其他西歐語言,其最多只能用 8 位來表示(一個位元組),即:2**8 = 256,所以,ASCII碼最多只能表示 256 個符號。


顯然ASCII碼無法將世界上的各種文字和符號全部表示,所以,就需要新出一種可以代表所有字元和符號的編碼,即:Unicode
Unicode(統一碼、萬國碼、單一碼)是一種在電腦上使用的字元編碼。Unicode 是為了解決傳統的字元編碼方案的局限而產生的,它為每種語言中的每個字元設定了統一併且唯一的二進位編碼,規定雖有的字元和符號最少由 16 位來表示(2個位元組),即:2 **16 = 65536, 註:此處說的的是最少2個位元組,可能更多
UTF-8,是對Unicode編碼的壓縮和優化,他不再使用最少使用2個位元組,而是將所有的字元和符號進行分類:ascii碼中的內容用1個位元組保存、歐洲的字元用2個位元組保存,東亞的字元用3個位元組保存…
所以,python解釋器在載入 .py 文件中的程式碼時,會對內容進行編碼(默認ascill),如果是如下程式碼的話:
報錯:ascii碼無法表示中文
1 2 3 |
#!/usr/bin/env python print "Hello, my name is ai huidi" |
---|
改正:應該顯示的告訴python解釋器,用什麼編碼來執行源程式碼,即:
1 2 3 4 |
#!/usr/bin/env python # -*- coding: utf-8 -*- print "Hello, my name is ai huidi" |
---|
4、注釋
當行注視:# 被注釋內容
多行注釋:""" 被注釋內容 """
5、執行腳本的傳入
Python有大量的模組,從而使得開發Python程式非常簡潔。類庫有包括三中:
- Python內部提供的模組
- 業內開源的模組
- 程式設計師自己開發的模組
Python內部提供一個 sys 的模組,其中的 sys.argv 用來捕獲執行執行python腳本時傳入的參數
1 2 3 4 5 6 |
#!/usr/bin/env python # -*- coding: utf-8 -*- import sys print sys.argv |
---|
6、什麼是pyc文件
執行Python程式碼時,如果導入了其他的 .py 文件,那麼,執行過程中會自動生成一個與其同名的 .pyc 文件,該文件就是Python解釋器編譯之後產生的位元組碼。
ps:需注意的是:程式碼經過編譯可以產生位元組碼;位元組碼通過反編譯也可以得到程式碼。
7、變數的理解與使用
1、聲明變數
1 2 3 4 |
#!/usr/bin/env python # -*- coding: utf-8 -*- name = "aihuidi" |
---|
上述程式碼聲明了一個變數,變數名為: name,變數name的值為:"aihuidi"
變數的作用:昵稱,其代指記憶體里某個地址中保存的內容

變數定義的規則:
- 變數名只能是 字母、數字或下劃線的任意組合
- 變數名的第一個字元不能是數字
- 以下關鍵字不能聲明為變數名 ['and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'exec', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'print', 'raise', 'return', 'try', 'while', 'with', 'yield']
2、變數的賦值
#! /usr/bin/env python # -*- coding: utf-8 -*- name1 = "aihuidi" name2 = "hhhhh"

#! /usr/bin/env python # -*- coding: utf-8 -*- name1 = "aihuidi" name2 = name1

8、輸入
#!/usr/bin/env python # -*- coding: utf-8 -*- # 將用戶輸入的內容賦值給 name 變數 name = input("請輸入用戶名:") # 列印輸入的內容 print name
9、初始基本數據類型
- 2 是一個整數的例子。
- 3.23和52.3E-4是浮點數的例子。E標記表示10的冪。在這裡,52.3E-4表示52.3 * 10-4。
- (-5+4j)和(2.3-4.6j)是複數的例子。
int(整型) 在32位機器上,整數的位數為32位,取值範圍為-2**31~2**31-1,即-2147483648~2147483647 在64位系統上,整數的位數為64位,取值範圍為-2**63~2**63-1,即-9223372036854775808~9223372036854775807 long(長整型) 跟C語言不同,Python的長整數沒有指定位寬,即:Python沒有限制長整數數值的大小,但實際上由於機器記憶體有限,我們使用的長整數數值不可能無限大。 注意,自從Python2.2起,如果整數發生溢出,Python會自動將整數數據轉換為長整數,所以如今在長整數數據後面不加字母L也不會導致嚴重後果了。 float(浮點型) 浮點數用來處理實數,即帶有小數的數字。類似於C語言中的double類型,佔8個位元組(64位),其中52位表示底,11位表示指數,剩下的一位表示符號。 complex(複數) 複數由實數部分和虛數部分組成,一般形式為x+yj,其中的x是複數的實數部分,y是複數的虛數部分,這裡的x和y都是實數。 註:Python中存在小數字池:-5 ~ 257 2、布爾值 真或假 1 或 0
3、字元串
"hello world"
萬惡的字元串拼接:
python中的字元串在C語言中體現為是一個字元數組,每次創建字元串時候需要在記憶體中開闢一塊連續的空,並且一旦需要修改字元串的話,就需要再次開闢空間,萬惡的+號每出現一次就會在內從中重新開闢一塊空間。
相加就是簡單拼接:

相乘就是複製自己,再拼接在一起

字元串格式化
name = "aihuidi" print("我的名字是: %s" %name) #輸出: 我的名字是: aihuidi
PS: 需注意:字元串是 %s、整數 %d、浮點數%f
字元串的常用功能:
- 移除空白
- 分割
- 長度
- 索引
- 切片
4、列表
創建一個列表:
name_list = ['aihuidi','hhhhh','ddddd'] print(name_list) #列印出結果:['aihuidi', 'hhhhh', 'ddddd'] name_list = ['aihuidi','hhhhh','ddddd'] print(name_list[1]) #列印出結果:hhhhh
基本操作:
- 索引
- 切片
- 追加
- 刪除
- 長度
- 切片
- 循環
- 包含
5、元組
ages = (1,2,3,4,5,666,) #或 ages = tuple((1,2,3,4,5,666))
基本操作:
- 索引
- 切片
- 循環
- 長度
- 包含
6、字典(無序)
person = {"name": "aihuidi",'age': 19} #或 person = dict({"nane": "aihuidi",'age':19})
常用操作:
- 索引
- 新增
- 刪除
- 鍵、值、鍵值對
- 循環
- 長度
PS:需注意:循環,range,continue 和 break
10、運算
算數運算:

比較運算:

賦值運算:

邏輯運算:

成員運算:

身份運算:

位運算:

運算符優先順序:

更多內容》》》:猛擊這裡!!!
11、三元運算
1 |
result = 值1 if 條件 else 值2 |
---|
如果條件為真:result = 值1 如果條件為假:result = 值2
12、進位
- 二進位,01
- 八進位,01234567
- 十進位,0123456789
- 十六進位,0123456789ABCDEF