1. 程式人生 > >Day1 python基礎

Day1 python基礎

過程 info global prop 版本 invalid and 會有 豆瓣

一、python介紹

目前Python主要應用領域:

  • 雲計算: 雲計算最火的語言, 典型應用OpenStack
  • WEB開發: 眾多優秀的WEB框架,眾多大型網站均為Python開發,Youtube, Dropbox, 豆瓣。。。, 典型WEB框架有Django
  • 科學運算、人工智能: 典型庫NumPy, SciPy, Matplotlib, Enthought librarys,pandas
  • 系統運維: 運維人員必備語言
  • 金融:量化交易,金融分析,在金融工程領域,Python不但在用,且用的最多,而且重要性逐年提高。原因:作為動態語言的Python,語言結構清晰簡單,庫豐富,成熟穩定,科學計算和統計分析都很牛逼,生產效率遠遠高於c,c++,java,尤其擅長策略回測
  • 圖形GUI: PyQT, WxPython,TkInter

Python的優缺點

先看優點

  1. Python的定位是“優雅”、“明確”、“簡單”,所以Python程序看上去總是簡單易懂,初學者學Python,不但入門容易,而且將來深入下去,可以編寫那些非常非常復雜的程序。
  2. 開發效率非常高,Python有非常強大的第三方庫,基本上你想通過計算機實現任何功能,Python官方庫裏都有相應的模塊進行支持,直接下載調用後,在基礎庫的基礎上再進行開發,大大降低開發周期,避免重復造輪子。
  3. 高級語言————當你用Python語言編寫程序的時候,你無需考慮諸如如何管理你的程序使用的內存一類的底層細節
  4. 可移植性————由於它的開源本質,Python已經被移植在許多平臺上(經過改動使它能夠工 作在不同平臺上)。如果你小心地避免使用依賴於系統的特性,那麽你的所有Python程序無需修改就幾乎可以在市場上所有的系統平臺上運行
  5. 可擴展性————如果你需要你的一段關鍵代碼運行得更快或者希望某些算法不公開,你可以把你的部分程序用C或C++編寫,然後在你的Python程序中使用它們。
  6. 可嵌入性————你可以把Python嵌入你的C/C++程序,從而向你的程序用戶提供腳本功能。

再看缺點:

  1. 速度慢,Python 的運行速度相比C語言確實慢很多,跟JAVA相比也要慢一些,因此這也是很多所謂的大牛不屑於使用Python的主要原因,但其實這裏所指的運行速度慢在大多數情況下用戶是無法直接感知到的,必須借助測試工具才能體現出來,比如你用C運一個程序花了0.01s,用Python是0.1s,這樣C語言直接比Python快了10倍,算是非常誇張了,但是你是無法直接通過肉眼感知的,因為一個正常人所能感知的時間最小單位是0.15-0.4s左右,哈哈。其實在大多數情況下Python已經完全可以滿足你對程序速度的要求,除非你要寫對速度要求極高的搜索引擎等,這種情況下,當然還是建議你用C去實現的。
  2. 代碼不能加密,因為PYTHON是解釋性語言,它的源碼都是以名文形式存放的,不過我不認為這算是一個缺點,如果你的項目要求源代碼必須是加密的,那你一開始就不應該用Python來去實現。
  3. 線程不能利用多CPU問題,這是Python被人詬病最多的一個缺點,GIL即全局解釋器鎖(Global Interpreter Lock),是計算機程序設計語言解釋器用於同步線程的工具,使得任何時刻僅有一個線程在執行,Python的線程是操作系統的原生線程。在Linux上為pthread,在Windows上為Win thread,完全由操作系統調度線程的執行。一個python解釋器進程內有一條主線程,以及多條用戶程序的執行線程。即使在多核CPU平臺上,由於GIL的存在,所以禁止多線程的並行執行。關於這個問題的折衷解決方法,我們在以後線程和進程章節裏再進行詳細探討。

    當然,Python還有一些其它的小缺點,在這就不一一列舉了,我想說的是,任何一門語言都不是完美的,都有擅長和不擅長做的事情,建議各位不要拿一個語言的劣勢去跟另一個語言的優勢來去比較,語言只是一個工具,是實現程序設計師思想的工具,就像我們之前中學學幾何時,有的時候需要要圓規,有的時候需要用三角尺一樣,拿相應的工具去做它最擅長的事才是正確的選擇。之前很多人問我Shell和Python到底哪個好?我回答說Shell是個腳本語言,但Python不只是個腳本語言,能做的事情更多,然後又有鉆牛角尖的人說完全沒必要學Python, Python能做的事情Shell都可以做,只要你足夠牛B,然後又舉了用Shell可以寫俄羅斯方塊這樣的遊戲,對此我能說表達只能是,不要跟SB理論,SB會把你拉到跟他一樣的高度,然後用充分的經驗把你打倒。

Python解釋器
當我們編寫Python代碼時,我們得到的是一個包含Python代碼的以.py為擴展名的文本文件。要運行代碼,就需要Python解釋器去執行.py文件。

由於整個Python語言從規範到解釋器都是開源的,所以理論上,只要水平夠高,任何人都可以編寫Python解釋器來執行Python代碼(當然難度很大)。事實上,確實存在多種Python解釋器。

CPython

當我們從Python官方網站下載並安裝好Python 2.7後,我們就直接獲得了一個官方版本的解釋器:CPython。這個解釋器是用C語言開發的,所以叫CPython。在命令行下運行python就是啟動CPython解釋器。
CPython是使用最廣的Python解釋器。教程的所有代碼也都在CPython下執行。

IPython

IPython是基於CPython之上的一個交互式解釋器,也就是說,IPython只是在交互方式上有所增強,但是執行Python代碼的功能和CPython是完全一樣的。好比很多國產瀏覽器雖然外觀不同,但內核其實都是調用了IE。
CPython用>>>作為提示符,而IPython用In [序號]:作為提示符。

PyPy

PyPy是另一個Python解釋器,它的目標是執行速度。PyPy采用JIT技術,對Python代碼進行動態編譯(註意不是解釋),所以可以顯著提高Python代碼的執行速度。
絕大部分Python代碼都可以在PyPy下運行,但是PyPy和CPython有一些是不同的,這就導致相同的Python代碼在兩種解釋器下執行可能會有不同的結果。如果你的代碼要放到PyPy下執行,就需要了解PyPy和CPython的不同點。

Jython

Jython是運行在Java平臺上的Python解釋器,可以直接把Python代碼編譯成Java字節碼執行。

IronPython

IronPython和Jython類似,只不過IronPython是運行在微軟.Net平臺上的Python解釋器,可以直接把Python代碼編譯成.Net的字節碼。

Python的解釋器很多,但使用最廣泛的還是CPython。如果要和Java或.Net平臺交互,最好的辦法不是用Jython或IronPython,而是通過網絡調用來交互,確保各程序之間的獨立性

二、Python發展史

  • 1989年,為了打發聖誕節假期,Guido開始寫Python語言的編譯器。Python這個名字,來自Guido所摯愛的電視劇Monty Python’s Flying Circus。他希望這個新的叫做Python的語言,能符合他的理想:創造一種C和shell之間,功能全面,易學易用,可拓展的語言。
  • 1991年,第一個Python編譯器誕生。它是用C語言實現的,並能夠調用C語言的庫文件。從一出生,Python已經具有了:類,函數,異常處理,包含表和詞典在內的核心數據類型,以及模塊為基礎的拓展系統。
  • Granddaddy of Python web frameworks, Zope 1 was released in 1999
  • Python 1.0 - January 1994 增加了 lambda, map, filter and reduce.
  • Python 2.0 - October 16, 2000,加入了內存回收機制,構成了現在Python語言框架的基礎
  • Python 2.4 - November 30, 2004, 同年目前最流行的WEB框架Django 誕生
  • Python 2.5 - September 19, 2006
  • Python 2.6 - October 1, 2008
  • Python 2.7 - July 3, 2010
  • In November 2014, it was announced that Python 2.7 would be supported until 2020, and reaffirmed that there would be no 2.8 release as users were expected to move to Python 3.4+ as soon as possible
  • Python 3.0 - December 3, 2008
  • Python 3.1 - June 27, 2009
  • Python 3.2 - February 20, 2011
  • Python 3.3 - September 29, 2012
  • Python 3.4 - March 16, 2014
  • Python 3.5 - September 13, 2015

三、Python 2 or 3?

In summary : Python 2.x is legacy, Python 3.x is the present and future of the language

Python 3.0 was released in 2008. The final 2.x version 2.7 release came out in mid-2010, with a statement of

extended support for this end-of-life release. The 2.x branch will see no new major releases after that. 3.x is

under active development and has already seen over five years of stable releases, including version 3.3 in 2012,

3.4 in 2014, and 3.5 in 2015. This means that all recent standard library improvements, for example, are only

available by default in Python 3.x.

Guido van Rossum (the original creator of the Python language) decided to clean up Python 2.x properly, with less regard for backwards compatibility than is the case for new releases in the 2.x range. The most drastic improvement is the better Unicode support (with all text strings being Unicode by default) as well as saner bytes/Unicode separation.

Besides, several aspects of the core language (such as print and exec being statements, integers using floor division) have been adjusted to be easier for newcomers to learn and to be more consistent with the rest of the language, and old cruft has been removed (for example, all classes are now new-style, "range()" returns a memory efficient iterable, not a list as in 2.x).

py2與3的詳細區別

PRINT IS A FUNCTION

The statement has been replaced with a print() function, with keyword arguments to replace most of the special syntax of the old statement (PEP 3105). Examples:

Old: print "The answer is", 2*2 New: print("The answer is", 2*2)
Old: print x, # Trailing comma suppresses newline New: print(x, end=" ") # Appends a space instead of a newline
Old: print # Prints a newline
New: print() # You must call the function!
Old: print >>sys.stderr, "fatal error" New: print("fatal error", file=sys.stderr)
Old: print (x, y) # prints repr((x, y))
New: print((x, y)) # Not the same as print(x, y)!

You can also customize the separator between items, e.g.:

print("There are <", 2**32, "> possibilities!", sep="")

ALL IS UNICODE NOW

從此不再為討厭的字符編碼而煩惱

還可以這樣玩: (A,*REST,B)=RANGE(5)

<strong>>>> a,*rest,b = range(5)
>>> a,rest,b
(0, [1, 2, 3], 4)
</strong>

某些庫改名了

Old Name New Name
_winreg winreg
ConfigParser configparser
copy_reg copyreg
Queue queue
SocketServer socketserver
markupbase _markupbase
repr reprlib
test.test_support test.support

四、安裝

windows

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

linux,mac

無需安裝,原裝Python環境

ps:如果自帶2.6,請更新至2.7

五、Hello World 程序

命令行執行
技術分享圖片

文件執行

[root@iZ25lubr06bZ ~]# vim hello.py 
print("Hello World!")
print("Hello again.")
print("Hello again \ntwo.")
[root@iZ25lubr06bZ ~]# python3 hello.py 
Hello World!
Hello again.
Hello again 
two.

[root@iZ25lubr06bZ ~]# ll hello.py 
-rw-r--r-- 1 root root 72 Jul 19 12:09 hello.py
[root@iZ25lubr06bZ ~]# chmod +x hello.py 
[root@iZ25lubr06bZ ~]# ll hello.py 
-rwxr-xr-x 1 root root 72 Jul 19 12:09 hello.py
[root@iZ25lubr06bZ ~]# ./hello.py 
./hello.py: line 1: syntax error near unexpected token `"Hello World!"‘
./hello.py: line 1: `print("Hello World!")‘          #不能解釋語法
[root@iZ25lubr06bZ ~]# vim hello.py 

#!/usr/bin/env python3                               #用什麽語言去解釋
print("Hello World!")
print("Hello again.")
print("Hello again \ntwo.")

[root@iZ25lubr06bZ ~]# ./hello.py 
Hello World!
Hello again.
Hello again 
two.

指定解釋器
上一步中執行 python hello.py 時,明確的指出 hello.py 腳本由 python 解釋器來執行。
如果想要類似於執行shell腳本一樣執行python腳本,例: ./hello.py ,那麽就需要在 hello.py 文件的頭部指定解釋器。
若只有系統默認python可寫為“#!/usr/bin/python”,若存在多個版本或者非默認安裝的python,用env去查找python解釋器。最好的寫法如下

#!/usr/bin/env python

print "hello,world"

如此一來,執行: ./hello.py 即可。
ps:執行前需給予 hello.py 執行權限,chmod 755 hello.py

六、變量/字符編碼

#!/usr/bin/env python3
# -*- coding:utf8 -*-
# Author: Erick Zhang

#聲明變量
name = "Alex Li"
name2 = name
print("My name is ", name,name2)

name = "PaoChe Ge"

print(name,name2)

運行結果:

"C:\Program Files\Python36\python.exe" F:/oldboy_python/day1/var2.py
My name is  Alex Li Alex Li
PaoChe Ge Alex Li

變量定義規則:

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

變量起名

  1. 顯示,要通俗易懂
  2. 硬性規則,nums_of_alex_gf = 19 下劃線式
  3. NumsOfAlexGf = 2 駝峰式
  4. .names-of-alex-gf = 22 不合法
  5. 5name = 數字不能開頭, na5me =
  6. !name 特殊字符不能有,~!@#$%^&*()-+=
  7. name of teacher = 不能有空格
  8. 某些關鍵字不能聲明為變量

字符編碼
python解釋器在加載 .py 文件中的代碼時,會對內容進行編碼(默認ascill)
ASCII(American Standard Code for Information Interchange,美國標準信息交換代碼)是基於拉丁字母的一套電腦編碼系統,主要用於顯示現代英語和其他西歐語言,其最多只能用 8 位來表示(一個字節),即:2**8 = 256-1,所以,ASCII碼最多只能表示 255 個符號。

技術分享圖片

關於中文

為了處理漢字,程序員設計了用於簡體中文的GB2312和用於繁體中文的big5。
GB2312(1980年)一共收錄了7445個字符,包括6763個漢字和682個其它符號。漢字區的內碼範圍高字節從B0-F7,低字節從A1-FE,占用的碼位是72*94=6768。其中有5個空位是D7FA-D7FE。
GB2312 支持的漢字太少。1995年的漢字擴展規範GBK1.0收錄了21886個符號,它分為漢字區和圖形符號區。漢字區包括21003個字符。2000年的 GB18030是取代GBK1.0的正式國家標準。該標準收錄了27484個漢字,同時還收錄了藏文、蒙文、維吾爾文等主要的少數民族文字。現在的PC平臺必須支持GB18030,對嵌入式產品暫不作要求。所以手機、MP3一般只支持GB2312。
從ASCII、GB2312、GBK 到GB18030,這些編碼方法是向下兼容的,即同一個字符在這些方案中總是有相同的編碼,後面的標準支持更多的字符。在這些編碼中,英文和中文可以統一地處理。區分中文編碼的方法是高字節的最高位不為0。按照程序員的稱呼,GB2312、GBK到GB18030都屬於雙字節字符集 (DBCS)。
有的中文Windows的缺省內碼還是GBK,可以通過GB18030升級包升級到GB18030。不過GB18030相對GBK增加的字符,普通人是很難用到的,通常我們還是用GBK指代中文Windows內碼。

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

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

註:此處說的的是最少2個字節,可能更多

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

所以,python解釋器在加載.py文件中的代碼時,會對內容進行編碼(默認ASCII),在python2中如果是如下代碼的話:
報錯:ascii碼無法顯示中文

#!/usr/bin/env python
name = "你好,世界"
print(name)

運行結果

C:\Python27\python.exe D:/oldboy_python/day1/coding.py
  File "D:/oldboy_python/day1/coding.py", line 5
SyntaxError: Non-ASCII character ‘\xe4‘ in file D:/oldboy_python/day1/coding.py on line 5, but no encoding declared; see http://python.org/dev/peps/pep-0263/ for details

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

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

註釋

單行註釋
#代碼

多行註釋
"""
代碼
"""

七、用戶輸入

1、新建一個文件interaction.py,輸入如下內容

username = input("username:")
password = input("password:")
print(username,password)

運行結果

"C:\Program Files\Python36\python.exe" F:/oldboy_python/day1/interaction.py
username:alex
password:123456
alex 123456

2、將interaction.py文件改為如下內容

name = input("name:")
age = input("age:")
job = input("job:")
salary = input("salary:")

info = ‘‘‘
-------- info of ‘‘‘ + name + ‘‘‘ --------
Name:‘‘‘ + name + ‘‘‘
Age:‘‘‘ + age + ‘‘‘
Job:‘‘‘ + job + ‘‘‘
Salary:‘‘‘ + salary

print(info)

運行結果

"C:\Program Files\Python36\python.exe" F:/oldboy_python/day1/interaction.py
name:alex
age:23
job:IT
salary:20000

-------- info of alex --------
Name:alex
Age:23
Job:IT
Salary:20000

3、繼續修改interation.py的內容

name = input("name:")
age = input("age:")
job = input("job:")
salary = input("salary:")

info = ‘‘‘
------- info of %s -------
Name:%s
Age:%s
Job:%s
Salary:%s
‘‘‘ % (name,name,age,job,salary)

print(info)

運行結果

"C:\Program Files\Python36\python.exe" F:/oldboy_python/day1/interaction.py
name:alex
age:23
job:IT
salary:3000

------- info of alex -------
Name:alex
Age:23
Job:IT
Salary:3000

4、將age的修改為%d

name = input("name:")
age = input("age:")
job = input("job:")
salary = input("salary:")

info = ‘‘‘
------- info of %s -------
Name:%s
Age:%d
Job:%s
Salary:%s
‘‘‘ % (name,name,age,job,salary)

print(info)

運行結果出報錯

"C:\Program Files\Python36\python.exe" F:/oldboy_python/day1/interaction.py
name:alex
age:23
job:IT
salary:3000
Traceback (most recent call last):
  File "F:/oldboy_python/day1/interaction.py", line 30, in <module>
    ‘‘‘ % (name,name,age,job,salary)
TypeError: %d format: a number is required, not str

5、python3默認所有輸入都是字符串,需要將字符串強制轉換為int類型

name = input("name:")
age = int(input("age:"))
job = input("job:")
salary = input("salary:")

info = ‘‘‘
------- info of %s -------
Name:%s
Age:%d
Job:%s
Salary:%s
‘‘‘ % (name,name,age,job,salary)

print(info)

運行結果

"C:\Program Files\Python36\python.exe" F:/oldboy_python/day1/interaction.py
name:alex
age:23
job:IT
salary:3000

------- info of alex -------
Name:alex
Age:23
Job:IT
Salary:3000

6、python2裏的raw_input與python3中input功能完全是一樣的。python2中也有input函數,但它輸入的是什麽格式就是什麽格式
技術分享圖片

input函數在python2中默認不加引號代表輸入的是一個變量,加引號代表輸入的是字符串

7.利用{}和變量名

info2 = ‘‘‘
------- info of {_name} -------
Name:{_name}
Age:{_age}
Job:{_job}
Salary:{_salary}
‘‘‘ .format (_name=name,
             _age=age,
             _job=job,
             _salary=salary)
print(info2)

運行結果

"C:\Program Files\Python36\python.exe" F:/oldboy_python/day1/interaction.py
name:alex
age:18
job:IT
salary:4000

------- info of alex -------
Name:alex
Age:18
Job:IT
Salary:4000

8.利用{}加數字,必須從0開始代表第一個參數

info3 = ‘‘‘
------- info of {0} -------
Name:{0}
Age:{1}
Job:{2}
Salary:{3}
‘‘‘.format(name,age,job,salary)
print(info3)

運行結果

"C:\Program Files\Python36\python.exe" F:/oldboy_python/day1/interaction.py
name:alex
age:18
job:IT
salary:4000

------- info of alex -------
Name:alex
Age:18
Job:IT
Salary:4000

8.密碼密文
新建password.py

import getpass
username = input("username:")
password = getpass.getpass("password:")

print(username,password)

在cmd命令行運行(pycharm不支持getpass),密碼輸入時不會明文顯示

C:\Users\Administrator>python F:\oldboy_python\day1\passwd.py
username:alex
password:
alex fsdf

八、if...else...

1.簡單if...else...語句

_username = ‘alex‘
_password = ‘abc123‘
username = input("username:")
password = input("password:")

if _username == username and _password == password:
    print("Welcome user {name} login ...".format(name=username))
else:
    print("Invalid username or password!")

運行輸入的錯誤結果:

"C:\Program Files\Python36\python.exe" F:/oldboy_python/day1/passwd.py
username:alex
password:bdf
Invalid username or password!

運行輸入正確結果:

"C:\Program Files\Python36\python.exe" F:/oldboy_python/day1/passwd.py
username:alex
password:abc123
Welcome user alex login ..

2.猜年齡
新建文件guess.py

age_of_oldboy = 56

guess_age = int(input("guess age:"))

if guess_age == age_of_oldboy:
    print("yes,you got it.")
elif guess_age > age_of_oldboy:
    print("think smaller ...")
else:
    print("think bigger!")

運行結果,每次運行輸入三個不同的數

"C:\Program Files\Python36\python.exe" F:/oldboy_python/day1/guess.py
guess age:23
think bigger!

"C:\Program Files\Python36\python.exe" F:/oldboy_python/day1/guess.py
guess age:57
think smaller ...

"C:\Program Files\Python36\python.exe" F:/oldboy_python/day1/guess.py
guess age:56
yes,you got it.

九、while循環

1.無限循環,count一直在累加

count = 0
while True:
    print("count:",count)
    count = count + 1   #count +=1

2.跳出循環break

count = 0
while True:
    print("count:",count)
    count = count + 1   #count +=1
    if count == 1000:
        break

3.猜年齡,利用break結束

age_of_oldboy = 56
while True:
    guess_age = int(input("guess age:"))
    if guess_age == age_of_oldboy:
        print("yes,you got it.")
        break
    elif guess_age > age_of_oldboy:
        print("think smaller ...")
    else:
        print("think bigger!")

運行結果:

"C:\Program Files\Python36\python.exe" D:/oldboy_python/day1/guess.py
guess age:23
think bigger!
guess age:59
think smaller ...
guess age:56
yes,you got it.

4.通過if限制次數

age_of_oldboy = 56
count = 0
while True:
    if count ==3:
        break
    guess_age = int(input("guess age:"))
    if guess_age == age_of_oldboy:
        print("yes,you got it.")
        break
    elif guess_age > age_of_oldboy:
        print("think smaller ...")
    else:
        print("think bigger!")
    count += 1

運行結果:

"C:\Program Files\Python36\python.exe" D:/oldboy_python/day1/guess.py
guess age:23
think bigger!
guess age:34
think bigger!
guess age:78
think smaller ...

5.while直接限制次數

age_of_oldboy = 56
count = 0
while count < 3:
    guess_age = int(input("guess age:"))
    if guess_age == age_of_oldboy:
        print("yes,you got it.")
        break
    elif guess_age > age_of_oldboy:
        print("think smaller ...")
    else:
        print("think bigger!")
    count += 1

運行結果:

"C:\Program Files\Python36\python.exe" D:/oldboy_python/day1/guess.py
guess age:23
think bigger!
guess age:45
think bigger!
guess age:99
think smaller ...

5.輸出提示次數太多

age_of_oldboy = 56
count = 0
while count < 3:
    guess_age = int(input("guess age:"))
    if guess_age == age_of_oldboy:
        print("yes,you got it.")
        break
    elif guess_age > age_of_oldboy:
        print("think smaller ...")
    else:
        print("think bigger!")
    count += 1
else:
    print("you have tried too many times...fuck off!")

運行結果:

"C:\Program Files\Python36\python.exe" D:/oldboy_python/day1/guess.py
guess age:23
think bigger!
guess age:45
think bigger!
guess age:90
think smaller ...
you have tried too many times...fuck off!

6.自由選擇超過三次是否繼續

age_of_oldboy = 56
count = 0
while count < 3:
    guess_age = int(input("guess age:"))
    if guess_age == age_of_oldboy:
        print("yes,you got it.")
        break
    elif guess_age > age_of_oldboy:
        print("think smaller ...")
    else:
        print("think bigger!")
    count += 1
    if count == 3:
        continue_confirm = input("do you want to keep guessing...?")
        if continue_confirm != ‘n‘:
            count = 0

運行結果:

"C:\Program Files\Python36\python.exe" D:/oldboy_python/day1/guess任性玩.py
guess age:23
think bigger!
guess age:45
think bigger!
guess age:67
think smaller ...
do you want to keep guessing...?y
guess age:34
think bigger!
guess age:67
think smaller ...
guess age:33
think bigger!
do you want to keep guessing...?n

Process finished with exit code 0

十、for循環

1.簡單for循環

for i in range(10):
    print("loop",i)

運行結果:

"C:\Program Files\Python36\python.exe" D:/oldboy_python/day1/while.py
loop 0
loop 1
loop 2
loop 3
loop 4
loop 5
loop 6
loop 7
loop 8
loop 9

2.for循環猜年齡

age_of_oldboy = 56
count = 0
for i in range(3):
    guess_age = int(input("guess age:"))
    if guess_age == age_of_oldboy:
        print("yes,you got it.")
        break
    elif guess_age > age_of_oldboy:
        print("think smaller ...")
    else:
        print("think bigger!")
else:
    print("you have tried too many times...fuck off!")

運行結果:

"C:\Program Files\Python36\python.exe" D:/oldboy_python/day1/guess.py
guess age:23
think bigger!
guess age:44
think bigger!
guess age:87
think smaller ...
you have tried too many times...fuck off!

3.按指定步長打印數字

for i in range(0,10,2):
    print("loop",i)

運行結果:

"C:\Program Files\Python36\python.exe" D:/oldboy_python/day1/while.py
loop 0
loop 2
loop 4
loop 6
loop 8

4.continue用法,跳出本次循環,進入下一次循環

for i in range(0,10):
    if i < 5:
        print("loop ",i)
    else:
        continue
    print("hehe...")

運行結果:

loop  0
hehe...
loop  1
hehe...
loop  2
hehe...
loop  3
hehe...
loop  4
hehe...

5.嵌套for循環

for i in range(10):

    print(‘------------‘)
    for j in range(10):
        print(j)
for i in range(10):

    print(‘------------‘)
    for j in range(10):
        print(j)
        if j >5:
            break

作業

1.博客

2.編寫登陸接口

  • 輸入用戶名密碼
  • 認證成功後顯示歡迎信息
  • 輸錯三次後鎖定

3.多級菜單

  • 三級菜單
  • 可疑次選擇進入各子菜單
  • 所需知識點:列表、字典

十一、模塊初識

1.sys模塊

import sys
# print(sys.path)     # 打印環境變量
print(sys.argv)       # 打印參數
print(sys.argv[2])

2.os模塊

import os
# cmd_res = os.system("ls -l")  # 執行命令不保存結果
# print(cmd_res)      # 0是命令的返回值,代表執行成功
cmd_res1 = os.popen("ls -l")    # 將對象的內存地址傳給變量
cmd_res2 = os.popen("ls -l").read()     # 取出內存地址的內容
print(cmd_res1)     # 打印對象內存地址
print(cmd_res2)

os.mkdir("new_dir")     # 創建目錄

3.自己寫模塊引用
編寫模塊文件login.py

_username = ‘alex‘
_password = ‘123‘

user = input("請輸入用戶名:")
pwd = input("請輸入密碼:")

if user == _username and pwd == _password:
    print("Welcome user %s login!" % user)
else:
    print("Wrong username or password!")

# 打印輸入的內容
print(user, pwd)

在同級創建python文件引用

import login

運行結果:

請輸入用戶名:dsf
請輸入密碼:fsf
Wrong username or password!
dsf fsf

若將lonin.py移動到new_dir目錄,會導致引用將會失敗,報錯類似如下:

Traceback (most recent call last):
  File "/Users/erick/PycharmProjects/oldboy_python/day1/sys_mod.py", line 6, in <module>
    import login
ModuleNotFoundError: No module named ‘login‘

將lonin.py移動到python的安裝目錄下lib/site-packages中,可以在代碼文件中直接引用

import login

十二、pyc是什麽

1.python是一門解釋型語言
我初學Python時,聽到的關於Python的第一句話就是,Python是一門解釋性語言,我就這樣一直相信下去,直到發現了.pyc文件的存在。如果是解釋型語言,那麽生成的.pyc文件是什麽呢?c應該是compiled的縮寫才對啊!

2.解釋型和編譯型語言
計算機是不能夠識別高級語言的,所以當我們運行一個高級語言程序的時候,就需要一個“翻譯機”來從事把高級語言轉變成計算機能讀懂的機器語言的過程。這個過程分成兩類,第一種是編譯,第二種是解釋。
編譯型語言在程序執行之前,先會通過編譯器對程序執行一個編譯的過程,把程序轉變成機器語言。運行時就不需要翻譯,而直接執行就可以了。最典型的例子就是C語言。
解釋型語言就沒有這個編譯的過程,而是在程序運行的時候,通過解釋器對程序逐行作出解釋,然後直接運行,最典型的例子是Ruby。
通過以上的例子,我們可以來總結一下解釋型語言和編譯型語言的優缺點,因為編譯型語言在程序運行之前就已經對程序做出了“翻譯”,所以在運行時就少掉了“翻譯”的過程,所以效率比較高。但是我們也不能一概而論,一些解釋型語言也可以通過解釋器的優化來在對程序做出翻譯時對整個程序做出優化,從而在效率上超過編譯型語言。
此外,隨著Java等基於虛擬機的語言的興起,我們又不能把語言純粹地分成解釋型和編譯型這兩種。
用Java來舉例,Java首先是通過編譯器編譯成字節碼文件,然後在運行時通過解釋器給解釋成機器文件。所以我們說Java是一種先編譯後解釋的語言。

3.python到底是什麽
其實Python和Java/C#一樣,也是一門基於虛擬機的語言,我們先來從表面上簡單地了解一下Python程序的運行過程吧。
當我們在命令行中輸入python hello.py時,其實是激活了Python的“解釋器”,告訴“解釋器”:你要開始工作了。可是在“解釋”之前,其實執行的第一項工作和Java一樣,是編譯。
熟悉Java的同學可以想一下我們在命令行中如何執行一個Java的程序:
javac hello.java
java hello

4.簡述python的運行過程
在說這個問題之前,我們先來說兩個概念,PyCodeObject和pyc文件。
我們在硬盤上看到的pyc自然不必多說,而其實PyCodeObject則是Python編譯器真正編譯成的結果。我們先簡單知道就可以了,繼續向下看。
當python程序運行時,編譯的結果則是保存在位於內存中的PyCodeObject中,當Python程序運行結束時,Python解釋器則將PyCodeObject寫回到pyc文件中。
當python程序第二次運行時,首先程序會在硬盤中尋找pyc文件,如果找到,則直接載入,否則就重復上面的過程。
所以我們應該這樣來定位PyCodeObject和pyc文件,我們說pyc文件其實是PyCodeObject的一種持久化保存方式。

十三、數據類型

1.數字

2 是一個整數的例子。
長整數 不過是大一些的整數。
3.23和52.3E-4是浮點數的例子。E標記表示10的冪。在這裏,52.3E-4表示52.3 * 10-4。
(-5+4j)和(2.3-4.6j)是復數的例子,其中-5,4為實數,j為虛數,數學中表示復數是什麽?。

int(整型)

在32位機器上,整數的位數為32位,取值範圍為-231~231-1,即-2147483648~2147483647
在64位系統上,整數的位數為64位,取值範圍為-263~263-1,即-9223372036854775808~9223372036854775807

long(長整型)

跟C語言不同,Python的長整數沒有指定位寬,即:Python沒有限制長整數數值的大小,但實際上由於機器內存有限,我們使用的長整數數值不可能無限大。
註意,自從Python2.2起,如果整數發生溢出,Python會自動將整數數據轉換為長整數,所以如今在長整數數據後面不加字母L也不會導致嚴重後果了。
註:python3中只有整型沒有長整型

float(浮點型)

先掃盲 http://www.cnblogs.com/alex3714/articles/5895848.html
浮點數用來處理實數,即帶有小數的數字。類似於C語言中的double類型,占8個字節(64位),其中52位表示底,11位表示指數,剩下的一位表示符號。

complex(復數)

復數由實數部分和虛數部分組成,一般形式為x+yj,其中的x是復數的實數部分,y是復數的虛數部分,這裏的x和y都是實數。
註:Python中存在小數字池:-5 ~ 257

2.布爾值

真或假
1 或 0
TRUE or False

3.數據運算
算數運算:
技術分享圖片

>>> 10 % 2
0
>>> 10 % 3
1
>>> 11 % 2
1
>>> 8 % 2
0
>>> 10.3 // 3
3.0
>>> 10.3 / 3
3.4333333333333336

比較運算:
技術分享圖片

註:<> ?在python3中不支持此運算符

賦值運算符:
技術分享圖片

邏輯運算:
技術分享圖片

>>> a,b,c = 3,5,7
>>> a > 2 and c < 7
False
>>> a > 2 and c < 8
True
>>> a > 2 and c < 8 and b > 7
False
>>> a > 2 and c < 8 and b > 4
True
>>> a > 2 and c < 8 and b > 4 or c == 8
True
>>> a > 2 and c < 2 and b > 4 or c == 8
False
>>> if not a > 2 and c < 2 and b > 4 or c == 8 :print(‘ddd‘)
... 
>>> a = ‘333‘
>>> if not a.isdigit():print(‘ddd‘)
... 
>>> if a.isdigit():print(‘ddd‘)
... 
ddd

成員運算:
技術分享圖片

>>> a = [1,2,3,4]
>>> if 1 not in a:print(‘sdfsf‘)
... 
>>> if 31 not in a:print(‘sdfsf‘)
... 
sdfsf

身份運算:
技術分享圖片

>>> a
[1, 2, 3, 4]
>>> type(a)
<class ‘list‘>
>>> type(a) is list
True
>>> type(‘333‘)
<class ‘str‘>
>>> type(‘333‘) is str

位運算:
技術分享圖片

#!/usr/bin/python

a = 60            # 60 = 0011 1100
b = 13            # 13 = 0000 1101
c = 0

c = a & b;        # 12 = 0000 1100
print "Line 1 - Value of c is ", c

c = a | b;        # 61 = 0011 1101
print "Line 2 - Value of c is ", c

c = a ^ b;        # 49 = 0011 0001 #相同為0,不同為1
print "Line 3 - Value of c is ", c

c = ~a;           # -61 = 1100 0011
print "Line 4 - Value of c is ", c

c = a << 2;       # 240 = 1111 0000
print "Line 5 - Value of c is ", c

c = a >> 2;       # 15 = 0000 1111
print "Line 6 - Value of c is ", c

運算符優先級:
技術分享圖片

十四、bytes數據類型

1.三元運算

result = 值1 if 條件 else 值2

如果條件為真:result = 值1
如果條件為假:result = 值2

>>> a,b,c = 1,3,5
>>> d = a if a > b else c
>>> d
5
>>> d = a if a < b else c
>>> d
1

2.進制

  • 二進制,01
  • 八進制,01234567
  • 十進制,0123456789
  • 十六進制,0123456789ABCDEF
    二進制到16進制轉換http://jingyan.baidu.com/album/47a29f24292608c0142399cb.html?picindex=1

計算機內存地址和為什麽用16進制?
為什麽用16進制
1、計算機硬件是0101二進制的,16進制剛好是2的倍數,更容易表達一個命令或者數據。十六進制更簡短,因為換算的時候一位16進制數可以頂4位2進制數,也就是一個字節(8位進制可以用兩個16進制表示)
2、最早規定ASCII字符集采用的就是8bit(後期擴展了,但是基礎單位還是8bit),8bit用2個16進制直接就能表達出來,不管閱讀還是存儲都比其他進制要方便
3、計算機中CPU運算也是遵照ASCII字符集,以16、32、64的這樣的方式在發展,因此數據交換的時候16進制也顯得更好
4、為了統一規範,CPU、內存、硬盤我們看到都是采用的16進制計算
16進制用在哪裏
1、網絡編程,數據交換的時候需要對字節進行解析都是一個byte一個byte的處理,1個byte可以用0xFF兩個16進制來表達。通過網絡抓包,可以看到數據是通過16進制傳輸的。
2、數據存儲,存儲到硬件中是0101的方式,存儲到系統中的表達方式都是byte方式
3、一些常用值的定義,比如:我們經常用到的html中color表達,就是用的16進制方式,4個16進制位可以表達好幾百萬的顏色信息。

3.bytes類型

python 3最重要的新特性大概要算是對文本和二進制數據作了更為清晰的區分。文本總是Unicode,由str類型表示,二進制數據則由bytes類型表示。Python 3不會以任意隱式的方式混用str和bytes,正是這使得兩者的區分特別清晰。你不能拼接字符串和字節包,也無法在字節包裏搜索字符串(反之亦然),也不能將字符串傳入參數為字節包的函數(反之亦然)

不管怎樣,字符串和字節包之間的界線是必然的,下面的圖解非常重要,務請牢記於心:
技術分享圖片

字符串可以編碼成字節包,而字節包可以解碼成字符串。

>>> ‘€20‘.encode(‘utf-8‘)
b‘\xe2\x82\xac20‘
>>> b‘\xe2\x82\xac20‘.decode(‘utf-8‘)
‘€20‘

msg = "我愛北京天安門"
print(msg)
print(msg.encode(encoding="utf-8"))
print(msg.encode(encoding="utf-8").decode(encoding="utf-8"))

Day1 python基礎