天天看點

02.萬惡之源-運算符和編碼

一. 格式化輸出

現在有以下需求,讓使用者輸入name, age, job,hobby 然後輸出如下所示:
------------ info of Alex Li -----------
Name : Alex Li
Age : 22
job : Teacher
Hobbie: girl
------------- end ----------------      

你怎麼實作呢?你會發現,用字元拼接的方式還難實作這種格式的輸出,是以一起來學一下新姿勢

隻需要把要列印的格式先準備好, 由于裡面的 一些資訊是需要使用者輸入的,你沒辦法預設知道,是以可以先放置 個占位符,再把字元串裡的占位符與外部的變量做個映射關系就好啦

name = input("Name:")
age = input("Age:")
job = input("Job:")
hobby = input("Hobbie:")
info = '''
------------ info of %s ----------- #這裡的每個%s就是一個占位符,本行的代表 後面拓号裡的 name
Name : %s #代表 name
Age : %s #代表 age
job : %s #代表 job
Hobbie: %s #代表 hobbie
------------- end -----------------
''' % (name,name,age,job,hobbie) # 這行的 % 号就是 把前面的字元串 與拓号 後面的 變量 關聯起來
print(info)      

%s就是代表字元串占位符,除此之外,還有%d, 是數字占位符, 如果把上面的age後面的換成%d,就代表你

必須隻能輸入數字啦

這時對應的資料必須是int類型. 否則程式會報錯

使用時,需要進行類型轉換.

int(str) # 字元串轉換成int
str(int) # int轉換成字元串      

類似這樣的操作在後面還有很多

如果, 你頭鐵. 就不想轉換. 覺着轉換很麻煩. 也可以全部都用%s. 因為任何東西都可以直接轉換成字元串--> 僅 限%s

現在又來新問題了. 如果想輸出:

我叫xxx, 今年xx歲了,我們已經學習了2%的python基礎了      

這裡的問題出在哪裡呢? 沒錯2%, 在字元串中如果使用了%s這樣的占位符. 那麼所有的%都将變成占位符. 我們的2%也變成了占 位符. 而"%的"是不存在的, 這裡我們需要使用%%來表示字元串中的%.

注意: 如果你的字元串中沒有使用過%s,%d站位. 那麼不需要考慮這麼多. 該%就%.沒毛病老鐵

print("我叫%s, 今年22歲了, 學習python2%%了" % '王尼瑪') # 有%占位符
print("我叫王尼瑪, 今年22歲, 已經涼涼了100%了") # 沒有占位符      

二. 基本運算符

計算機可以進行的運算有很多種,可不隻加減乘除這麼簡單,運算按種類可分為:

算數運算、

比較運算、

邏輯運算、

指派運算、

成員運算、

身份運算、

位運算.

   今天我們暫隻學習算數運算、比較運算、邏輯運算、指派運算

2.1 算數運算

以下假設變量:a=10,b=20

2.2 比較運算

以下假設變量:a=10,b=20

指派運算

以下假設變量:a=10,b=20

算邏輯運

針對邏輯運算的進一步研究:

    1, 在沒有()的情況下not 優先級高于 and,and優先級高于or,即優先級關系為( )>not>and>or,同一優 先級從左往右計算。

    () > not > and > or

例題:

判斷下列邏輯語句的True,False。

3>4 or 4<3 and 1==1
1 < 2 and 3 < 4 or 1>2
2 > 1 and 3 < 4 or 4 > 5 and 2 < 1
1 > 2 and 3 < 4 or 4 > 5 and 2 > 1 or 9 < 8
1 > 1 and 3 < 4 or 4 > 5 and 2 > 1 and 9 > 8 or 7 < 6
not 2 > 1 and 3 < 4 or 4 > 5 and 2 > 1 and 9 > 8 or 7 < 6      

2, x or y , x為真,值就是x,x為假,值是y;

x and y, x為真,值是y,x為假,值是x。

例題:求出下列邏輯語句的值。

8 or 4
0 and 3
0 or 4 and 3 or 7 or 9 and 6      

三. 編碼的問題

python2解釋器在加載 .py 檔案中的代碼時,會對内容進行編碼(預設ascill),而python3對内容進行編碼的默 認為utf-8。

計算機:

早期. 計算機是美國發明的. 普及率不高, 一般隻是在美國使用. 是以. 最早的編碼結構就是按照美國人的習慣來 編碼的. 對應數字+字母+特殊字元一共也沒多少. 是以就形成了最早的編碼ASCII碼. 直到今天ASCII依然深深的 影響着我們.

ASCII(American Standard Code for Information Interchange,美國标準資訊交換代碼)是基于拉丁字母 的一套電腦編碼系統,主要用于顯示現代英語和其他西歐語言,其最多隻能用 8 位來表示(一個位元組),即: 2**8 = 256,是以,ASCII碼最多隻能表示 256 個符号。

随着計算機的發展. 以及普及率的提高. 流行到歐洲和亞洲. 這時ASCII碼就不合适了. 比如: 中文漢字有幾萬個. 而 ASCII最多也就256個位置. 是以ASCII不行了. 怎麼辦呢? 這時, 不同的國家就提出了不同的編碼用來适用于各自 的語言環境. 比如, 中國的GBK, GB2312, BIG5, ISO-8859-1等等. 這時各個國家都可以使用計算機了.

GBK, 國标碼占用2個位元組. 對應ASCII碼 GBK直接相容. 因為計算機底層是用英文寫的. 你不支援英文肯定不 行. 而英文已經使用了ASCII碼. 是以GBK要相容ASCII.

這裡GBK國标碼. 前面的ASCII碼部分. 由于使用兩個位元組. 是以對于ASCII碼而言. 前9位都是0

字母A:0100 0001 # ASCII
字母A:0000 0000 0100 0001 # 國标碼      

國标碼的弊端: 隻能中國用. 日本就垮了. 是以國标碼不滿足我們的使用. 這時提出了一個萬國碼Unicode

unicode一開始設計是每個字元兩個位元組. 設計完了. 發現我大中國漢字依然無法進行編碼. 隻能進行擴充. 擴充 成32位也就是4個位元組. 這回夠了. 但是. 問題來了. 中國字9萬多. 而unicode可以表示40多億. 根本用不了. 太浪 費了. 于是乎, 就提出了新的UTF編碼.可變長度編碼

UTF-8: 每個字元最少占8位. 每個字元占用的位元組數不定.根據文字内容進行具體編碼. 比如. 英文. 就一個位元組就 夠了. 漢字占3個位元組. 這時即滿足了中文. 也滿足了節約. 也是目前使用頻率最高的一種編碼

UTF-16: 每個字元最少占16位.

GBK: 每個字元占2個位元組, 16位.

機關轉換:

8bit = 1byte

1024byte = 1KB

1024KB = 1MB

1024MB = 1GB

1024GB = 1TB

1024TB = 1PB

1024TB = 1EB

1024EB = 1ZB

1024ZB = 1YB

1024YB = 1NB

1024NB = 1DB

常用到TB就夠了

補充1: while循環

. while 條件:

循環體

else: 循環在正常情況跳出之後會執行這裡

index = 1
while index < 11:
 if index == 8:
 # break
 pass
 else:
 print(index)
 index = index+1
else:print("你好")      

注意: 如果循環是通過break退出的. 那麼while後面的else将不會被執行, 隻有在while條件判斷是假的時候才會 執行這個else

pass: 不表示任何内容. 為了代碼的完整性. 占位而已

補充2: in和not in

可以判斷xxx字元串是否出現在xxxxx字元串中

content = input("請輸入你的評論")
if "蒼老師" in content or '邱老師' in content:
 print('你輸入的内容不合法')
else:
 print("評論成功")