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