天天看點

8、for循環以及數字類型和字元串類型的内置方法

一、for循環

1.1、什麼是for循環

  循環就是重複做某件事,for循環是python提供第二種循環機制。

1.2、為何要有for循環

  理論上for循環能做的事情,while循環都可以做

  之是以要有for循環,是因為for循環在循環取值(周遊取值)比while循環更簡潔

1.3、如何用for循環

1.3.1、清單之循環取值 

 l = ['alex_dsb', 'lxx_dsb', 'egon_nb']

 for x in l: # x='lxx_dsb'

 print(x)

1.3.2、字典循環取值

# dic={'k1':111,'k2':2222,'k3':333}

# for k in dic:

# print(k,dic[k])

1.3.3、字元串循環取值

# msg="you can you up,no can no bb"

# for x in msg:

# print(x)

1.4、while循環與for循環的不同之處

 1、相同之處:都是循環,for循環可以幹的事,while循環也可以幹

 2、不同之處:

 while循環稱之為條件循環,循環次數取決于條件何時變為假

 for循環稱之為"取值循環",循環次數取決in後包含的值的個數

1.5、for循環控制循環次數:range()

in後直接放一個資料類型來控制循環次數有局限性:

當循環次數過多時,資料類型包含值的格式需要伴随着增加

for i in range(30)

    print('===>')

1.6、 for+break以及for+else:同while循環一樣

# username='egon'

# password='123'

# for i in range(3):

# inp_name = input('請輸入您的賬号:')

# inp_pwd = input('請輸入您的密碼:')

#

# if inp_name == username and inp_pwd == password:

# print('登入成功')

# break

# else:

# print('輸錯賬号密碼次數過多')

1.7、range補充知識(了解)

for搭配range,可以按照索引取值,但是麻煩,是以不推薦

# l=['aaa','bbb','ccc'] # len(l)

# for i in range(len(l)):

# print(i,l[i])

#

# for x in l:

# print(l)

1.8、for+continue

# for i in range(6): # 0 1 2 3 4 5

# if i == 4:

# continue

# print(i)

1.9、for循環嵌套:外層循環循環一次,内層循環需要完整的循環完畢

# for i in range(3):

# print('外層循環-->', i)

# for j in range(5):

# print('内層-->', j)

 補充:終止for循環隻有break一種方案

換行符:

print('hello

')

print('world',end='*')

二、數字類型

2.1、int類型

定義: age = 10 # age=int(10)

2.2、類型轉換

 純數字的字元串轉成int

 res=int('100111')

 print(res,type(res))

 2.3、(了解)

2.3.1.、十進制轉成其他進制

     10進制 -> 二進制

     11 - > 1011

     1011-> 8+2+1

     print(bin(11)) # 0b1011

 2.3.2、10進制 -> 八進制

      print(oct(11)) # 0o13

 2.3.3、10進制 -> 十六進制

     print(hex(11)) # 0xb

     print(hex(123)) # 0xb

三、float類型

3.1、定義salary=3.1   # salary=float(3.1)

3.2、類型轉換

 res=float("3.1")

 print(res,type(res))

3.3、使用

 int與float沒有需要掌握的内置方法

 他們的使用就是數學運算+比較運算

四、str字元串類型

4.1、定義msg='hello' # msg=str('msg')

4.2、類型轉換

 str可以把任意其他類型都轉成字元串

 res=str({'a':1})

 print(res,type(res))

4.3、内置方法(優先掌握)

4.3.1、按索引取值(正向取+反向取) :隻能取

msg='hello world'

 print(msg[0])# 正向取

 print(msg[5]# 正向取

print(msg[-1])#反向取

4.3.2、切片:索引的拓展應用,從一個大字元串中拷貝出一個子字元串

msg='hello world'

 顧頭不顧尾

 res=msg[0:5] 

 print(res)

 print(msg)

4.3.3、步長

 res=msg[0:5:2] # 0 2 4

 print(res) # hlo

4.3.4、反向步長(了解)

 res=msg[5:0:-1]

 print(res) #" olle

4.3.5、長度len

 msg='hello world'

 print(len(msg))

4.3.6、成員運算in和not in

# 判斷一個子字元串是否存在于一個大字元串中

 print("alex" in "alex is sb")

 print("alex" not in "alex is sb")

 print(not "alex" in "alex is sb") # 不推薦使用

4.3.7、移除字元串左右兩側的符号strip

 預設去掉的空格

 msg=' egon '

 res=msg.strip()

 print(msg) # 不會改變原值

 print(res) # 是産生了新值

  舉例:

 inp_user=input('your name>>: ').strip() # inp_user=" egon"

 inp_pwd=input('your password>>: ').strip()

 if inp_user == 'egon' and inp_pwd == '123':

 print('登入成功')

 else:

 print('賬号密碼錯誤')

4.3.8、切分split:把一個字元串按照某種分隔符進行切分,得到一個清單

 指定分隔次數(了解)

 info='egon:18:male'

 res=info.split('x',y)

 print(res)

x為指定分隔符,y為分隔次數

4.3 需要掌握

4.3.1、strip,lstrip,rstrip分隔符

 msg='***egon****'

 print(msg.strip('*'))    

 print(msg.lstrip('*'))

 print(msg.rstrip('*'))

4.3.2、lower,upper 純大小寫

 msg='AbbbCCCC'

 print(msg.lower())

 print(msg.upper())

4.3.3、startswith,endswith  判斷開頭結尾是否正确

 print("alex is sb".startswith("alex"))

 print("alex is sb".endswith('sb'))

4.3.4、format 格式化輸出

4.3.5、split,rsplit:将字元串切成清單

 info="egon:18:male"

 print(info.split(':',1)) # ["egon","18:male"]

 print(info.rsplit(':',1)) # ["egon:18","male"]

4.3.6、join: 把清單拼接成字元串

l=[1,"2",'aaa']

 ":".join(l)     #按照某個分隔符号,把元素全為字元串的清單拼接成一個大字元串

4.3.7、replace  替換

# msg="you can you up no can no bb"

# print(msg.replace("you","YOU",))

# print(msg.replace("you","YOU",1))

4.3.8、isdigit    # 判斷字元串是否由純數字組成

# print('123'.isdigit())

# print('12.3'.isdigit())

4.3.9、find,rfind,index,rindex,count

msg='hello egon hahaha'

# 找到傳回起始索引

# print(msg.find('e')) # 傳回要查找的字元串在大字元串中的起始索引,找不到為-1

# print(msg.index('xxx')) # 找到為1,找不到抛出異常

# msg='hello egon hahaha egon、 egon'

# print(msg.count('egon'))  #統計出現次數

4.3.10、center,ljust,rjust,zfill    第一位設定寬值,第二位補充字元

# print('egon'.center(50,'*'))

# print('egon'.ljust(50,'*'))

# print('egon'.rjust(50,'*'))

# print('egon'.zfill(10))   居右,設定寬值,用0補充

4.3.11、expandtabs      # 設定制表符代表的空格數為2取代

# msg='hello world'

# print(msg.expandtabs(2))

4.3.12、captalize,swapcase,title

# print("hello world egon".capitalize())   #首字母大寫

# print("Hello WorLd EGon".swapcase())   #大小寫翻轉

# print("hello world egon".title())   #每個單詞首字母大寫

4.3.13、is其他

# print('abc'.islower())  是否為純小寫

# print('ABC'.isupper())   是否為純大寫

# print('Hello World'.istitle())   是否每個單詞開頭為大寫

# print('123123aadsf'.isalnum()) # 字元串由字母或數字組成結果為True

# print('ad'.isalpha()) # 字元串由由字母組成結果為True

# print(' '.isspace()) # 字元串由空格組成結果為True

# print('print'.isidentifier())  是否屬于辨別符:符合變量名的命名

4.3.14、數字的識别

isdigit隻能識别:阿拉伯字母,以及bytes

isnumberic可以識别:阿拉伯字母,漢字數字,羅馬數字

isdecimal隻能識别隻能識别:阿拉伯數字