我的python之路day2
一. 格式化輸出
生活中有各式各樣的需求,為了滿足這些需求我們不停探索,現在有以下需求,讓用戶輸入name, age, job,hobby 然後輸出如下所示:
你怎麽實現呢?你會發現,用字符拼接的方式還難實現這種格式的輸出,所以一起來學一下新姿勢 只需要把要打印的格式先準備好, 由於裏面的 一些信息是需要用戶輸入的,你沒辦法預設知道,因此可以先放置 個占位符,再把字符串裏的占位符與外部的變量做個映射關系就好啦
%s就是代表字符串占位符,除此之外,還有%d, 是數字占位符, 如果把上面的age後面的換成%d,就代表你 必須只能輸入數字啦
這時對應的數據必須是int類型. 否則程序會報錯
使用時,需要進行類型轉換.
類似這樣的操作在後面還有很多
如果, 你頭鐵. 就不想轉換. 覺著轉換很麻煩. 也可以全部都用%s. 因為任何東西都可以直接轉換成字符串--> 僅 限%s 現在又來新問題了. 如果想輸出:
這裏的問題出在哪裏呢? 沒錯2%, 在字符串中如果使用了%s這樣的占位符. 那麽所有的%都將變成占位符. 我們的2%也變成了占 位符. 而"%的"是不存在的, 這裏我們需要使用%%來表示字符串中的%.
註意: 如果你的字符串中沒有使用過%s,%d站位. 那麽不需要考慮這麽多. 該%就%.沒毛病老鐵.
二. 基本運算符
計算機可以進行的運算有很多種,可不只加減乘除這麽簡單,運算按種類可分為:
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。
2, x or y , x為真,值就是x,x為假,值是y;
x and y, x為真,值是y,x為假,值是x。
例題:求出下列邏輯語句的值。
三. 編碼的問題
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
國標碼的弊端: 只能中國用. 日本就垮了. 所以國標碼不滿足我們的使用. 這時提出了一個萬國碼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: 循環在正常情況跳出之後會執行這裏
註意: 如果循環是通過break退出的. 那麽while後面的else將不會被執行, 只有在while條件判斷是假的時候才會 執行這個else
pass: 不表示任何內容. 為了代碼的完整性. 占位而已
補充2: in和not in
可以判斷xxx字符串是否出現在xxxxx字符串中
我的python之路day2