Python學習之路第一節java
1.Python介紹python
2.Python安裝linux
3.第一個程序:Hello Worldc++
4.變量程序員
5.字符編碼shell
6.用戶輸入和格式化輸出vim
7.表達式if...else語句windows
8.表達式for 循環bash
9.break and continue網絡
10.表達式while 循環
1、Python介紹
python的創始人爲吉多·範羅蘇姆(Guido van Rossum)。1989年的聖誕節期間,吉多·範羅蘇姆爲了在阿姆斯特丹打發時間,決心開發一個新的腳本解釋程序,做爲ABC語言的一種繼承。
最新的TIOBE排行榜,Python趕超C++佔據第三, Python崇尚優美、清晰、簡單,是一個優秀並普遍使用的語言。
Python能夠應用於衆多領域,如:數據分析、組件集成、網絡服務、圖像處理、數值計算和科學計算等衆多領域。目前業內幾乎全部大中型互聯網企業都在使用Python,如:Youtube、Dropbox、BT、Quora(中國知乎)、豆瓣、知乎、Google、Yahoo!、Facebook、NASA、百度、騰訊、汽車之家、美團等。
目前Python主要應用領域:
Python在一些公司的應用:
2、Python安裝
一、下載安裝包 https://www.python.org/downloads/ 二、安裝 默認安裝路徑:C:\python27 三、配置環境變量 【右鍵計算機】--》【屬性】--》【高級系統設置】--》【高級】--》【環境變量】--》【在第二個內容框中找到 變量名爲Path 的一行,雙擊】 --> 【Python安裝目錄追加到變值值中,用 ; 分割】 如:原來的值;C:\python27,切記前面有分號
linux、Mac
無需安裝,原裝Python環境 ps:若是自帶2.6,請更新至2.7
3、第一個程序:Hello World
在linux 下建立一個文件叫hello.py,並輸入
print("Hello World!")
而後執行命令:python hello.py ,輸出
localhost:~ jieli$ vim hello.py localhost:~ jieli$ python hello.py Hello World!
指定解釋器
上一步中執行 python hello.py 時,明確的指出 hello.py 腳本由 python 解釋器來執行。
若是想要相似於執行shell腳本同樣執行python腳本,例: ./hello.py
,那麼就須要在 hello.py 文件的頭部指定解釋器,以下:
#!/usr/bin/env python print "hello,world"
如此一來,執行: ./hello.py
便可。
ps:執行前需給予 hello.py 執行權限,chmod 755 hello.py
4、變量
變量定義的規則:
變量的賦值
name = "View Yin" name2 = name print(name,name2) name = "Sheng" print("What is the value of name2 now?")
PS:常量須要大寫
5、字符編碼
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、GB23十二、GBK 到GB18030,這些編碼方法是向下兼容的,即同一個字符在這些方案中老是有相同的編碼,後面的標準支持更多的字符。在這些編碼中,英文和中文能夠統一地處理。區分中文編碼的方法是高字節的最高位不爲0。按照程序員的稱呼,GB23十二、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 文件中的代碼時,會對內容進行編碼(默認ascill),若是是以下代碼的話:
報錯:ascii碼沒法表示中文
#!/usr/bin/env python print "你好,世界"
改正:應該顯示的告訴python解釋器,用什麼編碼來執行源代碼,即:
#!/usr/bin/env python # -*- coding: utf-8 -*- print "你好,世界"
6、用戶輸入和格式化輸出
輸入
#!/usr/bin/env python #_*_coding:utf-8_*_ #name = raw_input("What is your name?") #only on python 2.x name = input("What is your name?") print("Hello " + name )
輸入密碼時,若是想要不可見,須要利用getpass 模塊中的 getpass方法,即:
#!/usr/bin/env python # -*- coding: utf-8 -*- import getpass # 將用戶輸入的內容賦值給 name 變量 pwd = getpass.getpass("請輸入密碼:") # 打印輸入的內容 print(pwd)
格式化輸出
name=input('name:')
age=int(input('age:')) #無論輸的是數字仍是字符串,Python 3.X都默認爲字符串類型
print(type(age),type(str(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)
info2='''
------info of {_name}------
Name:{_name}
Age:{_age}
Job:{_job}
Salary:{_salary}
'''.format(_name=name,_age=age,_job=job,_salary=salary)
print(info2)
info3='''
------info of {0}------
Name:{0}
Age:{1}
Job:{2}
Salary:{3}
'''.format(name,age,job,salary)
print(info3)
7、表達式if...else語句
場景1、用戶登錄驗證
# 提示輸入用戶名和密碼 # 驗證用戶名和密碼 # 若是錯誤,則輸出用戶名或密碼錯誤 # 若是成功,則輸出 歡迎,XXX! #!/usr/bin/env python # -*- coding: encoding -*- import getpass name = input('請輸入用戶名:') pwd = getpass.getpass('請輸入密碼:') if name == "Yin" and pwd == "abc123": print("歡迎,Yin!") else: print("用戶名或密碼錯誤")
場景2、猜年齡遊戲
在程序裏設定好你的年齡,而後啓動程序讓用戶猜想,用戶輸入後,根據他的輸入提示用戶輸入的是否正確,若是錯誤,提示是猜大了仍是小了
#!/usr/bin/env python # -*- coding: utf-8 -*- my_age =25 user_input = int(input("input your guess num:")) if user_input == my_age: print("yes, you got it !") elif user_input < my_age: print("Think oldder!") else: print("Think younger!")
8、表達式for 循環
最簡單的循環10次
#_*_coding:utf-8_*_ for i in range(10): print("loop:", i )
輸出:
loop: 0 loop: 1 loop: 2 loop: 3 loop: 4 loop: 5 loop: 6 loop: 7 loop: 8 loop: 9
9、break and continue
遇到小於5的循環次數就不走了,直接跳入下一次循環
for i in range(10): if i<5: continue #不往下走了,直接進入下一次loop print("loop:", i )
遇到大於5的循環次數就不走了,直接退出
for i in range(10): if i>5: break #不往下走了,直接跳出整個loop print("loop:", i )
10、表達式while 循環
count=0
while True:
print('count:',count)
count=count+1 #count +=1
if count==1001:
break
循環1000次就退出
如何實現讓用戶不斷的猜年齡,但到了三次後詢問用戶是否繼續,不繼續就退出:
age_of_yin=24count=0while count<3: guess_age = int(input('guess age:')) # 默認輸入的爲字符型 if guess_age==age_of_yin: print('恭喜,答對了!') break elif guess_age>age_of_yin: print('往小了想一想...') else: print('往大的想一想...') count=count+1 if count==3: countiue_confirm=input('Do you want to keep guess?') if countiue_confirm !='n': count=0 else: print('試了太屢次啦...byebye')