日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

【Python之路】第二篇--初识Python

發布時間:2023/11/27 生活经验 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【Python之路】第二篇--初识Python 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Python簡介?

  Python可以應用于眾多領域,如:數據分析、組件集成、網絡服務、圖像處理、數值計算和科學計算等眾多領域。目前業內幾乎所有大中型互聯網企業都在使用Python,如:Youtube、Dropbox、BT、Quora(中國知乎)、豆瓣、知乎、Google、Yahoo!、Facebook、NASA、百度、騰訊、汽車之家、美團等。互聯網公司廣泛使用Python來做的事一般有:自動化運維自動化測試大數據分析、爬蟲、Web 等。

Python的種類

    • Cpython
      ? ? Python的官方版本,使用C語言實現,使用最為廣泛,CPython實現會將源文件(py文件)轉換成字節碼文件(pyc文件),然后運行在Python虛擬機上。
    • Jyhton
      ? ? Python的Java實現,Jython會將Python代碼動態編譯成Java字節碼,然后在JVM上運行。
    • IronPython
      ? ? Python的C#實現,IronPython將Python代碼編譯成C#字節碼,然后在CLR上運行。(與Jython類似)
    • PyPy(特殊)
      ? ? Python實現的Python,具有JIT(just In time)Compiler , 將Python的字節碼字節碼再編譯成機器碼。
    • RubyPython、Brython ...

?

為什么說pypy會比Cpython快?

代碼有兩種常見的執行方式,一種叫做編譯執行,也就是直接將代碼轉換為CPU指令,然后連續執行這些指令,好處當然是非常快,一條多余的指令都沒有;壞處則是難以支持許多動態特性。

一種叫做解釋執行,也就是對每條語句在運行時用解釋器去執行它相應的動作,好處是實現起來非常簡單,也很容易添加新特性,壞處則是執行得非常慢,大部分CPU時間花在了解釋器運行上面。

JIT技術是兩者的結合,首先讓代碼解釋執行,同時收集信息,在收集到足夠信息的時候,將代碼動態編譯成CPU指令,然后用CPU指令替代解釋執行的過程,因為編譯發生在馬上要執行之前,所以叫做Just-In-Time Compiler。編譯之后速度就是編譯執行的速度了,自然比解釋執行要快得多,所以運用JIT的PyPy要比CPython快不少。

安裝Python

  windows:

1、下載安裝包https://www.python.org/downloads/2、安裝默認安裝路徑:C:\python273、配置環境變量【右鍵計算機】--》【屬性】--》【高級系統設置】--》【高級】--》【環境變量】--》【在第二個內容框中找到 變量名為Path 的一行,雙擊】 --> 【Python安裝目錄追加到變值值中,用 ; 分割】如:原來的值 ;C:\python27 切記前面有分號!!    

  Linux:

無需安裝,原裝Python環境
ps:如果自帶2.6,請更新至2.7

更新Python:

  Windows:

卸載重裝即可

  Linux:

Linux的yum依賴自帶Python,為防止錯誤,此處更新其實就是再安裝一個Python查看默認Python版本
python -V1、安裝gcc,用于編譯Python源碼yum install gcc
2、下載源碼包,https://www.python.org/ftp/python/
3、解壓并進入源碼文件
4、編譯安裝./configuremake allmake install
5、查看版本/usr/local/bin/python2.7 -V
6、修改默認Python版本mv /usr/bin/python /usr/bin/python2.6ln -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 入門

解釋器

? ? ?我們經常在py腳本的第一行 看到如下的代碼:

#!/usr/bin/python  或者  #!/usr/bin/env python  那么它的作用是?

  #!/usr/bin/Python 是告訴操作系統執行這個腳本的時候,調用/usr/bin下的python解釋器;

  #!/usr/bin/env python這種用法是為了防止操作系統用戶沒有將python裝在默認的/usr/bin路徑里。當系統看到這一行的時候,首先會到env設置里查找python的安裝路徑,再調用對應路徑下的解釋器程序完成操作。推薦這種寫法

  如此一來,我們就可以通過:?./hello.py?執行即可。

  ps:執行前需給予 hello.py 執行權限,chmod 755 hello.py

內容編碼

  python解釋器在加載 .py 文件中的代碼時,會對內容進行編碼(默認ascill)

  顯然ASCII碼無法將世界上的各種文字和符號全部表示,所以,就需要新出一種可以代表所有字符和符號的編碼,即:Unicode

  Unicode(統一碼、萬國碼、單一碼)是一種在計算機上使用的字符編碼。Unicode 是為了解決傳統的字符編碼方案的局限而產生的,它為每種語言中的每個字符設定了統一并且唯一的二進制編碼,規定雖有的字符和符號最少由 16 位來表示(2個字節),即:2 **16 =?65536,注:此處說的的是最少2個字節,可能更多

  UTF-8,是對Unicode編碼的壓縮和優化,他不再使用最少使用2個字節,而是將所有的字符和符號進行分類:ascii碼中的內容用1個字節保存、歐洲的字符用2個字節保存,東亞的字符用3個字節保存...

  所以,python解釋器在加載 .py 文件中的代碼時,會對內容進行編碼(默認ascill),如果是如下代碼的話:

  報錯:ascii碼無法表示中文

#!/usr/bin/env pythonprint "你好,世界"

改正:應該顯示的告訴python解釋器,用什么編碼來執行源代碼,即:

#!/usr/bin/env python
# -*- coding: utf-8 -*-print "你好,世界"

Python2 中字符串的類型:

  Str:Bytes 類型

  Unicode:unicode 類型

# coding:utf8

s = '你好'
print len(s)     # 6
print type(s)   #  <str>
print repr(s)   #  utf8格式 : '\xe4\xbd\xa0\xe5\xa5\xbd'# Unicode 形式:

s = u'你好'
print len(s)     # 2
print type(s)   #  <unicode>
print repr(s)   #  u'\u4f60\u597d'# bytes 與 Unicode 混用拼接
print 'hello'+u'world'      # 先把 bytes => unicode
print '你好'+u'世界'         # 報錯, 只能將Ascii碼轉換,其余字符不行!

Python3 中字符串的類型:

  Str:Unicode 類型?

  Bytes:Bytes 類型

# bytes 與 Unicode 混用拼接
print 'hello'+b'world'      # 報錯,嚴格區分str和bytes

Python 編碼形式:

Python 編碼方式有兩種:

s = 'hello'
b = b'hello'#  編碼 encode  Str => Bytes
s.encode('utf8')
bytes(s,encoding='utf8')#  解碼 decode  Bytes => Str  (需要知道原先的編碼格式 utf8 or GBK ..)
b.decode('utf8')                 
str(s,encoding='utf8')

cmd 下的字符顯示問題:

print('你好')# py2下為bytes 類型,根據cmd的編碼形式去顯示 修改為:print(u'你好')
# py3下為unicode 類型,正常顯示,符合ISO統一標準的,

查看.py文件的編碼格式:

import sys
print sys.getdefaultencoding()# py2: ascii
# py3: utf8

print問題:

在py2里

# coding:utf8
print('你好')           # 你好
print(['你好','hello']) # ['\xe4\xbd\xa0\xe5\xa5\xbd', 'hello']

在py3里

# coding:utf8
print('你好')            # 你好
print(['你好','hello'])  # ['你好', 'hello']

Python 中,print語句都會執行了:str()

# python2
sys.stdout.write(str(A) + '\n')

栗子:py3,將中文字符轉換成二進制(bytes類型進行for循環print,會輸出10進制數!)

name = "李路"len(name)
#長度等于2for i in name:print(i)bytes_list = bytes(i , encoding='utf-8')print(bytes_list )for b in bytes_list:print(b,bin(b))#李
#b'\xe6\x9d\x8e'
#230 0b11100110
#157 0b10011101
#142 0b10001110
#路
#b'\xe8\xb7\xaf'
#232 0b11101000
#183 0b10110111
#175 0b10101111

Str 與 Bytes

x = str()
# 功能:
# 1.創建字符串
# 2.轉換成字符串	  編碼類型x = bytes()
# 功能:
# 1.創建字節
# 2.轉換成字節	編碼類型
def __init__(self, value='', encoding=None, errors='strict'): # known special case of str.__init__"""str(object='') -> strstr(bytes_or_buffer[, encoding[, errors]]) -> strCreate a new string object from the given object. If encoding orerrors is specified, then the object must expose a data bufferthat will be decoded using the given encoding and error handler.Otherwise, returns the result of object.__str__() (if defined)or repr(object).encoding defaults to sys.getdefaultencoding().errors defaults to 'strict'.# (copied from class doc)"""pass
str
def __init__(self, value=b'', encoding=None, errors='strict'): # known special case of bytes.__init__"""bytes(iterable_of_ints) -> bytesbytes(string, encoding[, errors]) -> bytesbytes(bytes_or_buffer) -> immutable copy of bytes_or_bufferbytes(int) -> bytes object of size given by the parameter initialized with null bytesbytes() -> empty bytes objectConstruct an immutable array of bytes from:- an iterable yielding integers in range(256)- a text string encoded using the specified encoding- any object implementing the buffer API.- an integer# (copied from class doc)"""pass
bytes

三、注釋

  單行注釋:# 被注釋內容

  多行注釋:""" 被注釋內容 """

四、執行腳本傳入參數

Python內部提供一個 sys 的模塊,其中的 sys.argv 用來捕獲執行執行python腳本時傳入的參數

#!/usr/bin/env python
# -*- coding: utf-8 -*-import sys
print sys.argv

比如用python test.py arg1 arg2運行test.py代碼,那么argv列表的內容是[' test.py','arg1','arg2']

五、 pyc 文件

執行Python代碼時,如果導入了其他的 .py 文件,那么,執行過程中會自動生成一個與其同名的 .pyc 文件,該文件就是Python解釋器編譯之后產生的字節碼。

ps:代碼經過編譯可以產生字節碼;字節碼通過反編譯也可以得到代碼。執行時優先搜索字節碼文件

六、變量

變量定義的規則:

  • 變量名只能是 字母、數字或下劃線的任意組合
  • 變量名的第一個字符不能是數字
  • 以下關鍵字不能聲明為變量名
  • ['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']

七、輸入

#!/usr/bin/env python
# -*- coding: utf-8 -*-# 將用戶輸入的內容賦值給 name 變量
name = raw_input("請輸入用戶名:")#python3
name = input("請輸入用戶名:")# 打印輸入的內容
print(name)

輸入密碼時,如果想要不可見,需要利用getpass 模塊中的 getpass方法,即:

#!/usr/bin/env python
# -*- coding: utf-8 -*-import getpass# 將用戶輸入的內容賦值給 name 變量
pwd = getpass.getpass("請輸入密碼:")# 打印輸入的內容
print pwd

八、流程控制和縮進

需求一、用戶登陸驗證

#!/usr/bin/env python
# -*- coding: encoding -*-# 提示輸入用戶名和密碼# 驗證用戶名和密碼
#     如果錯誤,則輸出用戶名或密碼錯誤
#     如果成功,則輸出 歡迎,XXX!import getpassname = raw_input('請輸入用戶名:')
pwd = getpass.getpass('請輸入密碼:')if name == "alex" and pwd == "cmd":print "歡迎,alex!"
else:print "用戶名和密碼錯誤"

需求二、根據用戶輸入內容輸出其權限

# 根據用戶輸入內容打印其權限# alex --> 超級管理員
# eric --> 普通管理員
# tony,rain --> 業務主管
# 其他 --> 普通用戶name = raw_input('請輸入用戶名:')if name == "alex":print "超級管理員"
elif name == "eric":print "普通管理員"
elif name == "tony" or name == "rain":print "業務主管"
else:print "普通用戶"

九、while循環

1、基本循環

while 條件:# 循環體# 如果條件為真,那么循環體則執行# 如果條件為假,那么循環體不執行

2、break

break用于退出所有循環

while True:print "123"breakprint "456"

3、continue

continue用于退出當前循環,繼續下一次循環

while True:print "123"continueprint "456"

?

十、練習題

1、使用while循環輸入 1 2 3 4 5 6 ? ? 8 9 10

1 #!/usr/bin/env python
2 # -*-coding:utf-8 -*-
3 num = 0
4 while num <10:
5     num += 1
6     if num == 7:
7         continue
8     print(num)
View Code

2、求1-100的所有數的和

1 #!/usr/bin/env python
2 # -*-coding:utf-8 -*-
3 num = 1
4 sum = 0
5 while num<=100:
6     sum = sum + num
7     num +=1
8 
9 print(sum)
View Code

3、輸出 1-100 內的所有奇數

 1 #!/usr/bin/env python
 2 # -*-coding:utf-8 -*-
 3 
 4 num = 1
 5 
 6 while 1:
 7     if  num % 2 == 1:
 8         print(num)
 9     num += 1
10     if num == 100:
11         break
View Code

4、輸出 1-100 內的所有偶數

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3  
 4 num = 1
 5  
 6 while 1:
 7     if num % 2 ==0:
 8         print(num)
 9     if num == 100:
10         break
11     num += 1
View Code

5、求1-2+3-4+5 ... 99的所有數的和

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3  
 4 num = 1
 5 sum =0
 6  
 7 while 1:
 8     if num == 100:
 9         break
10     if num % 2 == 1:
11         sum = sum + num
12     else:
13         sum = sum - num
14     num +=1
15  
16 print(sum)
View Code

6、用戶登陸(三次機會重試)

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3  
 4 count = 0
 5  
 6 while 1:
 7     if count == 3:
 8         break
 9     username = input("username :")
10     password = input("password :")
11  
12     if username == 'admin' and password == 'admin123':
13         print(" Welcome !")
14         break
15     else:
16         count +=1
17         continue
View Code

?

  

轉載于:https://www.cnblogs.com/5poi/p/6046495.html

總結

以上是生活随笔為你收集整理的【Python之路】第二篇--初识Python的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。