• 万恶之源-基本数据类型(list,tuple)


    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.      增

     注意, 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)

     

     

     

     

    2.      修改

     

    索引切片修改

     

    # 修改

    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])

     

    . 元组和元组嵌套

    元组: 俗称不可变的列表.⼜被成为只读列表, 元组也是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 = (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)

  • 相关阅读:
    toj 1410. Euclid's Game 夜
    hdu 1404 Digital Deletions 夜
    hdu 1536 SNim 夜
    1180. Stone Game 夜
    hdu 1729 Stone Game 夜
    一个有价值的 Sharepoint WebPart 页签部件
    开始 MS Project & P3 E/C 探讨历程!
    cvccomplextype.3.2.2: Attribute 'singleton' is not allowed to appear in element 'bean
    启迪技术
    上传图片:
  • 原文地址:https://www.cnblogs.com/kongjubeihou/p/9270718.html
Copyright © 2020-2023  润新知