python基础数据类型--列表(list)
列表是我们在后面经常用到的数据类型之一,通过列表可以对数据类型进行增、删、改、查等操作
一列表的增、删、改、查
1增:
1.1增加到最后 append()
li = ['alex','wusir','egon','女神','taibai']
li.append('xiaoqiang')
print(li)
1.2按索引位置添加 insert()
li = ['alex','wusir','egon','女神','taibai'] li.insert(3,'xingxing') print(li)
1.3迭代的去增加 extend()
li = ['alex','wusir','egon','女神','taibai']
li.extend('gaoya')#最终添加为元素
print(li)
2删
2.1按索引删除 pop()
|
1
2
3
|
li = ['alex','wusir','egon','女神','taibai']li.pop(0)print(li) |
2.2按元素删除remove()
li = ['alex','wusir','egon','女神','taibai']
li.remove('taibai')
print(li)
2.3清空clear()
li = ['alex','wusir','egon','女神','taibai'] li.clear() print(li)
2.4直接删除del()
|
1
2
3
|
li = ['alex','wusir','egon','女神','taibai']del liprint(li) 会报错,因为被删除了 |
2.5切片删除del()
|
1
2
3
|
li = ['alex','wusir','egon','女神','taibai']del [2:]print(li) |
3改
3.1按索引去改
|
1
2
3
|
li = ['alex','wusir','egon','女神','taibai']li[0]='xiaoqiang'print(li) |
3.2按切片去改
|
1
2
3
|
li = ['alex','wusir','egon','女神','taibai']li[0:2]='learnpython'print(li) |
4查
4.1 for循环
|
1
2
3
|
li = ['alex','wusir','egon','女神','taibai']for i in li: print(i) |
4.2切片去查
|
1
2
3
|
li = ['alex','wusir','egon','女神','taibai']l1 = li[0:2]print(l1) |
二、列表的排序
li = [1,3,4,5,7,6,8,9,2] li.sort() #正向排序 li.sort(reverse=True)#倒向排序 li.reverse() #反转 print(li)
三、列表是嵌套
li = ['taibai','武藤兰','苑昊',['alex','egon','89'],'23',] lan=li[1][2] #找到兰字 print(lan)
四、join和split
join()方法
S.join():其中S是字符串连接符,join中参数必须是可迭代对象,join()方法输出可迭代对象的每一个元素,并用连接符将每一个元素连接
s = 'ilovepython'
l = ['C','Java','C++','Ruby','PHP','Python']
print('_'.join(s))
# >>> 'i_l_o_v_e_p_y_t_h_o_n'
print('_'.join(l))
# >>> 'C_Java_C++_Ruby_PHP_Python'
split()方法
字符串和列表之间的转换
s = 'i_l_o_v_e_p_y_t_h_o_n'
print(s.split('_'))
# >>> ['i', 'l', 'o', 'v', 'e', 'p', 'y', 't', 'h', 'o', 'n']
五、range()
# range:相当于都是数字的列表 [0,1,2,3,4.....,99]
# range(起始值,终止值)
for i in range(0,100):
print(i)
# 默认起始值不写默认为0
for i in range(100):
print(i)
# 同索引一样,range也可以加步长,加步长的话默认的0起始值就不可以省略
for i in range(0,100,2):
print(i)
for i in range(100,0,-2):
print(i)
六、 enumerate()方法------有索引有值
枚举----对于一个可迭代的/可遍历的对象(如列表、字符串),enumerate将其组成一个索引序列,利用它可以同时或得索引和值
lst = ['python','java','c','ruby','Go']
for i in enumerate(lst):
print(i)
for index, name in enumerate(lst, 1): ####---1 是起始位置,可以修改100等等
print(index, name)
七、 深浅copy()简析
# 普通赋值运算
lst_1 = ['Python','Java',['Ruby','PHP','C++']]
lst_2 =lst_1 # lst_2 = lst_1[:] 同理
print(lst_1)
print(id(lst_1))
print('*'*10)
print(lst_2)
print(id(lst_2))
# >>> ['Python','Java',['Ruby','PHP','C++']]
# >>> 18623368
# >>> **********
# >>> ['Python','Java',['Ruby','PHP','C++']]
# >>> 18623368
# 浅copy()方法:第一层创建的是新的内存地址,而从第二层开始,指向的都是同一个内存地址,所以,对于第二层以及更深的层数来说,保持一致性。
lst_1 = ['Python','Java',['Ruby','PHP','C++']]
lst_2 =lst_1.copy() # lst_2 = lst_1[:] 同理
lst_1[2].append('new_lanuage')
print(lst_1,id(lst_1))
print('*'*10)
print(lst_2,id(lst_2))
# >>> ['Python', 'Java', ['Ruby', 'PHP', 'C++', 'new_lanuage']] 12001800
# >>> **********
# >>> ['Python', 'Java', ['Ruby', 'PHP', 'C++', 'new_lanuage']] 12015048
# 深copy()方法:对于深copy来说,两个是完全独立的,改变任意一个的任何元素(无论多少层),另一个绝对不改变。
import copy
lst_1 = ['Python','Java',['Ruby','PHP','C++']]
lst_2 = copy.deepcopy(lst_1)
lst_1[2].append('new_lanuage')
print(lst_1,id(lst_1))
print('*'*10)
print(lst_2,id(lst_2))
# >>> ['Python', 'Java', ['Ruby', 'PHP', 'C++', 'new_lanuage']] 12533000
# >>> **********
# >>> ['Python', 'Java', ['Ruby', 'PHP', 'C++']] 12533512