Python環境的安裝 安裝Python: windows: 1、下載安裝包 https://www.python.org/downloads/ 2、安裝 預設安裝路徑:C:\python27 3、配置環境變數 【右鍵電腦】--》【屬性】--》【高級系統設置】--》【高級】--》【環境變數】--》 ...
Python環境的安裝
安裝Python:
windows:
https://www.python.org/downloads/
2 、安裝
預設安裝路徑:C:\python27
3 、配置環境變數
【右鍵電腦】 - - 》【屬性】 - - 》【高級系統設置】 - - 》【高級】 - - 》【環境變數】 - - 》【在第二個內容框中找到 變數名為Path 的一行,雙擊】 - - > 【Python安裝目錄追加到變值值中,用 ; 分割】
如:原來的值;C:\python27,切記前面有分號
|
Linux:
無需安裝,原裝Python環境、
如果自帶
2.6
,請更新至
2.7
更新Python的方法:
windows:
進行卸載重裝 |
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
|
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 或 03、字元串 "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})
常用操作:
- 索引
- 新增
- 刪除
- 鍵、值、鍵值對
- 迴圈
- 長度
比較運算:
賦值運算:
邏輯運算:
成員運算:
身份運算:
位運算:
運算符優先順序:
更多內容》》》:猛擊這裡!!!
11、三元運算
1 |
result = 值 1 if 條件 else 值 2
|
如果條件為真:result = 值1
如果條件為假:result = 值2
12、進位
- 二進位,01
- 八進位,01234567
- 十進位,0123456789
- 十六進位,0123456789ABCDEF