03.萬惡之源-基本數據類型(int, bool, str)

⼀.python基本數據類型前端

1. int ==> 整數. 主要⽤來進⾏數學運算java

2. str ==> 字符串, 能夠保存少許數據並進⾏相應的操做python

3. bool==>判斷真假, True, Falsegit

4. list==> 存儲⼤量數據.⽤[ ]表⽰算法

5. tuple=> 元組, 不能夠發⽣改變 ⽤( )表⽰編程

6. dict==> 字典, 保存鍵值對, ⼀樣能夠保存⼤量數據api

  7. set==> 集合, 保存⼤量數據. 不能夠重複. 其實就是不保存value的dict函數

⼆. 整數(int) 在python3中全部的整數都是int類型. 但在python2中若是數據量比較⼤. 會使⽤long類型.spa

在python3中不存在long類型 整數能夠進⾏的操做: bit_length().code

三. 布爾值(bool) 取值只有True, False. bool值沒有操做.

轉換問題: str => int int(str) int => str str(int) int => bool bool(int). 0是False 非0是True bool=>int int(bool) True是1, False是0 str => bool bool(str) 空字符串是False, 不空是True bool => str str(bool) 把bool值轉換成相應的"值"

四. 字符串(str) 把字符連成串. 在python中⽤', ", ''', """引發來的內容被稱爲字符串. 

  1. 切片和索引 1. 索引. 索引就是下標. 切記, 下標從0開始

  2. 切片, 咱們可使⽤下標來截取部分字符串的內容 語法: str[start: end] 規則: 顧頭不顧腚, 從start開始截取. 截取到end位置. 但不包括end

  步⻓: 若是是整數, 則從左往右取. 若是是負數. 則從右往左取. 默認是1

   切片語法:

   str[start:end:step]      #  start: 起始位置 end: 結束位置 step:步⻓

  3. 字符串的相關操做⽅法 切記, 字符串是不可變的對象, 因此任何操做對原字符串是不會有任何影響的

  (1) ⼤⼩寫轉來轉去      # 應⽤, 校驗⽤戶輸⼊的驗證碼是否合法

  s1.capitalize()

  print(s1) # 輸出發現並無任何的變化. 由於這⾥的字符串自己是不會發⽣改變的. 須要咱們 從新獲取

  ret = s1.lower()      # 所有轉換成⼩寫

  print(ret)

 

  ret = s1.upper()      # 所有轉換成⼤寫

  print(ret)

   # 應⽤, 校驗⽤戶輸⼊的驗證碼是否合法

  verify_code = "abDe"

  user_verify_code = input("請輸⼊驗證碼:")

  if verify_code.upper() == user_verify_code.upper():

   print("驗證成功")

  else: print("驗證失敗")

 

  ret = s1.swapcase() # ⼤⼩寫互相轉換 print(ret)

  (2)切來切去

   s5 = "周杰倫" ret = s5.center(10, "*")       # 拉⻓成10, 把原字符串放中間.其他位置補*

   print(ret)

   s7 = " alex wusir haha "

 

 

   ret = s7.strip()      # 去掉左右兩端的空格

   print(ret)

 

   username = input("請輸⼊⽤戶名:").strip()     # 應⽤, 模擬⽤戶登陸. 忽略⽤戶輸⼊的空格

   password = input("請輸⼊密碼: ").strip()

   if username == 'alex' and password == '123':

    print("登陸成功")

   else: print("登陸失敗")

 

   s8 = "sylar_alex_taibai_wusir_eggon"

   ret = s8.replace('alex', '⾦⻆⼤王') # 把alex替換成⾦⻆⼤王 print(s8)

   

  

本節主要內容: 1. python基本數據類型回顧 2. int----數字類型 3. bool---布爾類型 4. str--- 字符串類型 ⼀.python基本數據類型 1. int ==> 整數. 主要⽤來進⾏數學運算 2. str ==> 字符串, 能夠保存少許數據並進⾏相應的操做 3. bool==>判斷真假, True, False 4. list==> 存儲⼤量數據.⽤[ ]表⽰ 5. tuple=> 元組, 不能夠發⽣改變 ⽤( )表⽰ 6. dict==> 字典, 保存鍵值對, ⼀樣能夠保存⼤量數據 7. set==> 集合, 保存⼤量數據. 不能夠重複. 其實就是不保存value的dict ⼆. 整數(int) 在python3中全部的整數都是int類型. 但在python2中若是數據量比較⼤. 會使⽤long類型. 在python3中不存在long類型 整數能夠進⾏的操做: bit_length(). 計算整數在內存中佔⽤的⼆進制碼的⻓度 ⼗進制 ⼆進制 ⻓度bit_length() 1 1 1 2 10 2 3 11 2 4 100 3 5 101 3 6 110 3 7 111 3 三. 布爾值(bool) 取值只有True, False. bool值沒有操做. 轉換問題: str => int int(str) int => str str(int) int => bool bool(int). 0是False 非0是True bool=>int int(bool) True是1, False是0 str => bool bool(str) 空字符串是False, 不空是True bool => str str(bool) 把bool值轉換成相應的"值" 四. 字符串(str) 把字符連成串. 在python中⽤', ", ''', """引發來的內容被稱爲字符串. 4.1 切片和索引 1. 索引. 索引就是下標. 切記, 下標從0開始 # 0123456 7 8 s1 = "python最⽜B" print(s1[0]) # 獲取第0個 print(s1[1]) print(s1[2]) print(s1[3]) print(s1[4]) print(s1[5]) print(s1[6]) print(s1[7]) print(s1[8]) # print(s1[9]) # 沒有9, 越界了. 會報錯 print(s1[-1]) # -1 表示倒數. print(s1[-2]) # 倒數第⼆個 2. 切片, 咱們可使⽤下標來截取部分字符串的內容 語法: str[start: end] 規則: 顧頭不顧腚, 從start開始截取. 截取到end位置. 但不包括end s2 = "python最⽜B" 8 1000 4 print(s2[0:3]) # 從0獲取到3. 不包含3. 結果: pyt print(s2[6:8]) # 結果 最⽜ print(s2[6:9]) # 最⼤是8. 但根據顧頭不顧腚, 想要取到8必須給9 print(s2[6:10]) # 若是右邊已通過了最⼤值. 至關於獲取到最後 print(s2[4:]) # 若是想獲取到最後. 那麼最後⼀個值能夠不給. print(s2[-1:-5]) # 從-1 獲取到 -5 這樣是獲取不到任何結果的. 從-1向右數. 你怎麼數 也數不到-5 print(s2[-5:-1]) # ⽜b, 取到數據了. 可是. 顧頭不顧腚. 怎麼取最後⼀個呢? print(s2[-5:]) # 什麼都不寫就是最後了 print(s2[:-1]) # 這個是取到倒數第⼀個 print(s2[:]) # 原樣輸出 跳着截取 # 跳着取, 步⻓ print(s2[1:5:2]) # 從第⼀個開始取, 取到第5個,每2個取1個, 結果: yh, 分析: 1:5=> ytho => yh print(s2[:5:2]) # 從頭開始到第五個. 每兩個取⼀個 print(s2[4::2]) # 從4開始取到最後. 每兩個取⼀個 print(s2[-5::2]) # 從-5取到最後.每兩個取⼀個 print(s2[-1:-5]) # -1:-5什麼都沒有. 由於是從左往右獲取的. print(s2[-1:-5:-1]) # 步⻓是-1. 這時就從右往左取值了 print(s2[-5::-3]) # 從倒數第5個開始. 到最開始. 每3個取⼀個, 結果oy 步⻓: 若是是整數, 則從左往右取. 若是是負數. 則從右往左取. 默認是1 切片語法: str[start:end:step] start: 起始位置 end: 結束位置 step:步⻓ 4.2 字符串的相關操做⽅法 切記, 字符串是不可變的對象, 因此任何操做對原字符串是不會有任何影響的 1. ⼤⼩寫轉來轉去 s1.capitalize() print(s1) # 輸出發現並無任何的變化. 由於這⾥的字符串自己是不會發⽣改變的. 須要咱們 從新獲取 ret1 = s1.capitalize() print(ret1) # ⼤⼩寫的轉換 ret = s1.lower() # 所有轉換成⼩寫 print(ret) ret = s1.upper() # 所有轉換成⼤寫 print(ret) # 應⽤, 校驗⽤戶輸⼊的驗證碼是否合法 verify_code = "abDe" user_verify_code = input("請輸⼊驗證碼:") if verify_code.upper() == user_verify_code.upper(): print("驗證成功") else: print("驗證失敗") ret = s1.swapcase() # ⼤⼩寫互相轉換 print(ret) # 不常⽤ ret = s1.casefold() # 轉換成⼩寫, 和lower的區別: lower()對某些字符⽀持不夠好. casefold()對全部字⺟都有效. ⽐如東歐的⼀些字⺟ print(ret) s2 = "БBß" # 俄美德 print(s2) print(s2.lower()) print(s2.casefold()) # 每一個被特殊字符隔開的字⺟⾸字⺟⼤寫 s3 = "alex eggon,taibai*yinwang_麻花藤" ret = s3.title() # Alex Eggon,Taibai*Yinwang_麻花藤 print(ret) # 中⽂也算是特殊字符 s4 = "alex⽼男孩wusir" # Alex⽼男孩Wusir print(s4.title()) 2. 切來切去 # 居中 s5 = "周杰倫" ret = s5.center(10, "*") # 拉⻓成10, 把原字符串放中間.其他位置補* print(ret) # 更改tab的⻓度 s6 = "alex wusir\teggon" print(s6) print(s6.expandtabs()) # 能夠改變\t的⻓度, 默認⻓度更改成8 # 去空格 s7 = " alex wusir haha " ret = s7.strip() # 去掉左右兩端的空格 print(ret) ret = s7.lstrip() # 去掉左邊空格 print(ret) ret = s7.rstrip() # 去掉右邊空格 print(ret) # 應⽤, 模擬⽤戶登陸. 忽略⽤戶輸⼊的空格 username = input("請輸⼊⽤戶名:").strip() password = input("請輸⼊密碼: ").strip() if username == 'alex' and password == '123': print("登陸成功") else: print("登陸失敗") s7 = "abcdefgabc" print(s7.strip("abc")) # defg 也能夠指定去掉的元素, # 字符串替換 s8 = "sylar_alex_taibai_wusir_eggon" ret = s8.replace('alex', '⾦⻆⼤王') # 把alex替換成⾦⻆⼤王 print(s8) # sylar_alex_taibai_wusir_eggon 切記, 字符串是不可變對象. 全部操做都 是產⽣新字符串返回 print(ret) # sylar_⾦⻆⼤王_taibai_wusir_eggon ret = s8.replace('i', 'SB', 2) # 把i替換成SB, 替換2個 print(ret) # sylar_alex_taSBbaSB_wusir_eggon # 字符串切割 s9 = "alex,wusir,sylar,taibai,eggon" lst = s9.split(",") # 字符串切割, 根據,進⾏切割 print(lst) s10 = """詩⼈ 學者 感嘆號 渣渣""" print(s10.split("\n")) # ⽤\n切割 # 坑 s11 = "銀王哈哈銀王呵呵銀王吼吼銀王" lst = s11.split("銀王") # ['', '哈哈', '呵呵', '吼吼', ''] 若是切割符在左右兩端. 那麼⼀ 定會出現空字符串.深坑請留意 print(lst) 3. 格式化輸出 # 格式化輸出 s12 = "我叫%s, 今年%d歲了, 我喜歡%s" % ('sylar', 18, '周杰倫') # 以前的寫法 print(s12) s12 = "我叫{}, 今年{}歲了, 我喜歡{}".format("周杰倫", 28, "周潤發") # 按位置格式化 print(s12) s12 = "我叫{0}, 今年{2}歲了, 我喜歡{1}".format("周杰倫", "周潤發", 28) # 指定位置 print(s12) s12 = "我叫{name}, 今年{age}歲了, 我喜歡{singer}".format(name="周杰倫", singer="周潤 發", age=28) # 指定關鍵字 print(s12) 4. 查找 s13 = "我叫sylar, 我喜歡python, java, c等編程語⾔." ret1 = s13.startswith("sylar") # 判斷是否以sylar開頭 print(ret1) ret2 = s13.startswith("我叫sylar") # 判斷是否以我叫sylar開頭 print(ret2) ret3 = s13.endswith("語⾔") # 是否以'語⾔'結尾 print(ret3) ret4 = s13.endswith("語⾔.") # 是否以'語⾔.'結尾 print(ret4) ret7 = s13.count("a") # 查找"a"出現的次數 print(ret7) ret5 = s13.find("sylar") # 查找'sylar'出現的位置 print(ret5) ret6 = s13.find("tory") # 查找'tory'的位置, 若是沒有返回-1 print(ret6) ret7 = s13.find("a", 8, 22) # 切⽚找 print(ret7) ret8 = s13.index("sylar") # 求索引位置. 注意. 若是找不到索引. 程序會報錯 print(ret8) 5. 條件判斷 # 條件判斷 s14 = "123.16" s15 = "abc" s16 = "_abc!@" # 是否由字⺟和數字組成 print(s14.isalnum()) print(s15.isalnum()) print(s16.isalnum()) # 是否由字⺟組成 print(s14.isalpha()) print(s15.isalpha()) print(s16.isalpha()) # 是否由數字組成, 不包括⼩數點 print(s14.isdigit()) print(s14.isdecimal()) print(s14.isnumeric()) # 這個⽐較⽜B. 中⽂都識別. print(s15.isdigit()) print(s16.isdigit()) # 練習. ⽤算法判斷某⼀個字符串是不是⼩數 s17 = "-123.12" s17 = s17.replace("-", "") # 替換掉負號 if s17.isdigit(): print("是整數") else: if s17.count(".") == 1 and not s17.startswith(".") and not s17.endswith("."): print("是⼩數") else: print("不是⼩數") 6. 計算字符串的⻓度 s18 = "我是你的眼, 我也是a" ret = len(s18) # 計算字符串的⻓度 print(ret) 注意: len()是python的內置函數. 因此訪問⽅式也不⼀樣. 你就記着len()和print()⼀樣就⾏ 了 7. 迭代 咱們可使⽤for循環來便利(獲取)字符串中的每⼀個字符 語法: for 變量 in 可迭代對象: pass 可迭代對象: 能夠⼀個⼀個往外取值的對象 s19 = "⼤家好, 我是VUE, 前端的⼩朋友們. 大家好麼?" # ⽤while循環 index = 0 while index < len(s19): print(s19[index]) # 利⽤索引切⽚來完成字符的查找 index = index + 1 # for循環, 把s19中的每⼀個字符拿出來賦值給前⾯的c for c in s19: print(c) ''' in有兩種⽤法: 1. 在for中. 是把每⼀個元素獲取到賦值給前⾯的變量. 2. 不在for中. 判斷xxx是否出如今str中. ''' print('VUE' in s19) # 練習, 計算在字符串"I am sylar, I'm 14 years old, I have 2 dogs!" s20 = "I am sylar, I'm 14 years old, I have 2 dogs!" count = 0 for c in s20: if c.isdigit(): count = count

相關文章
相關標籤/搜索