天天看點

基本資料類型-清單主要内容:

主要内容:

1. 列表

2. 清單的增删改查

3. 列表的嵌套

4. 元組和元組嵌套

5. range

一. 列表

   1.1   清單的介紹

       列表是python的基礎資料類型之⼀一 ,其他程式設計語⾔言也有類似的資料類型. 比如JS中的數組, java中的數組等等. 它是以[ ]括起來, 每個元素⽤用' , '隔開⽽而且可以存放各種資料類型:

    lst = [1, '哈哈', "吼吼", [1,8,0,"百度"], ("我","叫", "元", "組"), "abc", {"我 叫":"dict字典"},{"我叫集合","集合"}]

        清單相比于字元串. 不僅可以存放不同的資料類型. 而且可以存放⼤量的資料. 32位 python可以存放:  536870912個元素, 64位可以存放:  1152921504606846975個元素.⽽且列表是有序的(按照你儲存的順序),有索引, 可以切⽚方便取值.

    2.2  列表的索引和切片

列表和字元串⼀樣也擁有索引:

lst = ["麻花藤", "王劍林", "⻢芸", "周鴻醫", "向華強"]

print(lst[0])   # 擷取第⼀一個元素

print(lst[1])

print(lst[2])

lst[3] = "流動強"  # 注意. 列表是可以發⽣改變的. 這里和字元串不一樣

print(lst)  # ['麻花藤', '王劍林', '⻢芸', '流動強', '向華強']

s0 = "向華強"

s0[1] = "美"  # TypeError: 'str' object does not support item assignment 不允許改變

print(s0)

 清單的切片:

lst = ["麻花藤", "王劍林", "馬芸", "周鴻醫", "向華強"]

print(lst[0:3])     # ['麻花藤', '王劍林', '馬芸']

print(lst[:3])      # ['麻花藤', '王劍林', '馬芸']

print(lst[1::2])    # ['王劍林', '周鴻醫'] 也有步長

print(lst[2::-1])   # ['馬芸', '王劍林', '麻花藤'] 也可以倒着取

print(lst[-1:-3:-2])    # 倒着帶步⻓長    

二. 清單的增删改查

1. 增(append、insert、extend)

注意, list和str是不⼀一的. lst可以發生改變. 是以直接就在原來的對象上進行了操作

lst = ["麻花藤", "林林俊傑", "周潤發", "周芷若"]

print(lst) lst.append("wusir")

print(lst)

lst = []

while True:

   content = input("請輸⼊入你要錄⼊入的員⼯工資訊, 輸⼊入Q退出:")

   if content.upper() == 'Q':

       break

   lst.append(content)

print(lst) lst = ["麻花藤", "張德忠", "孔德福"]

lst.insert(1, "劉德華")    # 在1的位置插⼊入劉德華. 原來的元素向後移動一位

print(lst) # 疊代添加

lst = ["王志文", "張一山", "苦海無涯"]

lst.extend(["麻花藤", "麻花不不疼"])

print(lst)    

2. 删除    

pop, remove, clear, del

lst = ["麻花藤", "王劍林", "李嘉誠", "王富貴"]

print(lst)

deleted = lst.pop()         # 删除最後一個

print("被删除的", deleted)

print(lst)

el = lst.pop(2)     # 删除2号元素

print(el)

print(lst)

lst.remove("麻花藤")   # 删除指定元素

print(lst) #

lst.remove("哈哈")    # 删除不存在的元素會報錯 # #

print(lst)

lst.clear()     # 清空list

print(lst)

# 切片删除

del lst[1:3]

print(lst)

3. 修改

   索引切片修改

# 修改

lst = ["太⽩白", "太⿊黑", "五⾊色", "銀王", "⽇日天"]

lst[1] = "太污"   # 把1号元素修改成太污

print(lst)

lst[1:4:3] = ["麻花藤", "哇靠"]

    # 切⽚修改也OK. 如果步⻓不是1, 要注意. 元素的個數

print(lst)

lst[1:4] = ["李嘉誠個龜⼉子"]  # 如果切片沒有步長或者步長是1. 則不不⽤用關⼼個數

print(lst)

4. 查詢,

列表是一個可疊代對象, 是以可以進行for循環

for el in lst:

   print(el)

5. 其他操作

lst = ["太白", "太黑", "五色", "銀王", "日天", "太白"]

c = lst.count("太⽩白")     # 查詢太白出現的次數

print(c)

lst = [1, 11, 22, 2]

lst.sort()          # 排序. 預設升序

print(lst)

lst.sort(reverse=True)  # 降序

print(lst)

lst = ["太白", "太黑", "五色", "銀王", "日天", "太白"]

print(lst)

lst.reverse()

print(lst

l = len(lst)    # 清單的長度

print(l)

三. 清單的嵌套

   采⽤降維操作.一層一層的看就好. 

lst = [1, "太⽩白", "wusir", ["⻢馬⻁虎疼", ["可⼝口可樂"], "王劍林林"]]

# 找到wusir

print(lst[2])

# 找到太⽩白和wusir

print(lst[1:3])

# 找到太白的⽩字

print(lst[1][1])

# 将wusir拿到. 然後⾸字⺟⼤寫. 再扔回去

s = lst[2]

s = s.capitalize()

lst[2] = s print(lst)

# 簡寫

lst[2] = lst[2].capitalize()

print(lst)

# 把太白換成太黑

lst[1] = lst[1].replace("白", "黑")

print(lst)

# 把⻢虎換成馬化疼

lst[3][0] = lst[3][0].replace("虎", "化")

print(lst[3][0])

st[3][1].append("雪碧")

print(lst)

四. 元組和元組嵌套

   元組: 俗稱不可變的列表.又被成為隻讀列表, 元組也是python的基本資料類型之⼀一, 用小括号括起來, 里面可以放任何資料類型的資料,  查詢可以. 循環也可以. 切片也可以. 但就是不能.

tu = (1, "太白", "李白", "太黑", "怎麼黑")

print(tu)

print(tu[0])

print(tu[2])

print(tu[2:5])  # 切片之後還是元組

# for循環周遊元組

for el in tu:

   print(el)

# 嘗試修改元組

# tu[1] = "馬虎疼"   # 報錯 'tuple' object does not support item assignment

tu = (1, "哈哈", [], "呵呵")

# tu[2] = ["fdsaf"]   # 這麼改不⾏ 

tu[2].append("麻花藤")     # 可以改了. 沒報錯

tu[2].append("王劍林林")

print(tu)

   關于不可變, 注意: 這里元組的不可變的意思是子元素不可變. 而子元素内部的子元素是可以變, 這取決于子元素是否是可變對象.

    元組中如果隻有一個元素. 一定要添加⼀個逗号, 否則就不是元組

tu = (1,)

print(type(tu))

元組也有count(), index(), len()等⽅方法. 可以自己測試使用

五. range

   range可以幫我們擷取到一組資料. 通過for循環能夠擷取到這些資料.

for num in range(10):

   print(num)

for num in range(1, 10, 2):

   print(num)

for num in range(10, 1, -2): # 反着來, 和切⽚片⼀一樣

   print(num)