python基础数据类型列表(list)

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 li
print(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 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

  

 

原文地址:https://www.cnblogs.com/a438842265/p/8461774.html