day2——運算符和編碼

  • 2019 年 11 月 2 日
  • 筆記

運算符和編碼

一. 格式化輸出

現在有以下需求,讓用戶輸入name, age, job,Gender 然後輸出如下所示:

———— info of Yong Jie ———–

Name : Yong Jie

Age : 19

job : Programmer

Gender: Boy

————- end —————–

你怎麼實現呢?你會發現,用字元拼接的方式還難實現這種格式的輸出,所以一起來學一下新姿勢只需要把要列印的格式先準備好, 由於裡面的 一些資訊是需要用戶輸入的,你沒辦法預設知道,因此可以先放置個佔位符,再把字元串里的佔位符與外部的變數做個映射關係就好啦

name = input(“Name:”)

age = input(“Age:”)

job = input(“Job:”)

Gender = input(“Gender:”)

info = ”’

———— info of %s ———– #這裡的每個%s就是一個佔位符,本行的代表 後面拓號里的 name

Name : %s #代表 name

Age : %s #代表 age

job : %s #代表 job

Gender: %s #代表 Gender

————- end —————–

”’ % (name,name,age,job,Gender) # 這行的 % 號就是 把前面的字元串 與拓號 後面的變數 關聯起來

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, 今年19歲了, 學習python2%了” % ‘YJ’) # 有%佔位符

print(“我叫YJ, 今年19歲, 已經很厲害了100%了”) # 沒有佔位符

二. 基本運算符

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

  1. 算數運算、
  2. 比較運算、
  3. 邏輯運算、
  4. 賦值運算、
  5. 成員運算、
  6. 身份運算、
  7. 位運算.

今天我們暫只學習算數運算、比較運算、邏輯運算、賦值運算

 算數運算

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

 比較運算

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

賦值運算

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

算邏輯運

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

 在沒有()的情況下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

三. 編碼的問題

編碼:

1. ascill 最早的編碼. 至今還在使用. 8位一個位元組(字元)

2. Unicode 萬國碼. 32位4個位元組

3. GBK. 國標碼. 16位2個位元組.

4. UTF-8. 可變長度的unicode,英文: 8位1個位元組,歐洲文字:16位2個位元組,漢字24位3個位元組

        8bit = 1byte

        1024byte = 1KB

        1024KB = 1MB

        1024MB = 1GB

        1024GB = 1TB

python2解釋器在載入 .py 文件中的程式碼時,會對內容進行編碼(默認ascill),而python3對內容進行編碼的默認為utf-8

Python2 每個文件中只要出現中文,頭部必須加:# -*- coding:utf8 -*-否則會出現亂碼。

電腦:早期. 電腦是美國發明的. 普及率不高, 一般只是在美國使用. 所以. 最早的編碼結構就是按照美國人的習慣來編碼的. 對應數字+字母+特殊字元一共也沒多少. 所以就形成了最早的編碼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就夠了

2019年11月2日