Pyhton编程之基本数据类型-列表元组字典

Posted 无敌小怪兽

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Pyhton编程之基本数据类型-列表元组字典相关的知识,希望对你有一定的参考价值。

一:列表(list)

  列表是由一系列按特定顺序排列的元素组成,可以创建包含字母表中的所有字母、数字、或中文的列表,也可以将任何东西加入列表中,其中的元素之间可以没有任何关系。

  在Python中,用方括号[]来表示列表,并用,来分割列表中的元素,如

name=[1,2,3,"cc",[33,44]]        //列表可以嵌套任何类型,

  列表的取值

name=[1,2,3,"cc",[33,44]]
print(name[0])                    ##通过索引的方式
name=[1,2,3,"cc",[33,44]]
print(name[1:-1])                 ##通过切片的方式,注意:切片取前不取后

  列表的修改

name=[1,2,3,"cc",[33,44]]
name[0]=3
print(name)                ##通过索引赋值,可以修改列表中元素的值
##################
name[0:2]=[4,5,6]
print(name)                ##同样的,也可以通过切片的方式批量修改元素值 

  补充一下:字符串一旦创建,就不能修改,一旦修改或者拼接,都会造成重新生成字符串。列表可以进行修改。

二:列表的方法(详解)

  1、append

name=[1,2,3]
name.append("czp")
print(name)            //追加,将元素追加到列表的最后

  2、clear

name=[1,2,3]
print(name.clear())   #清空列表,返回值为None

  3、copy

name=[1,2,3]
v=name.copy()
print(v)               #浅拷贝,后面的博客会详细介绍深、浅拷贝

  4、count

name=[1,2,3,2,2]
print(name.count(2))   #计算元素出现的次数

  5、extend

name=[1,2,3]
name.extend([11,22])
print(name)             ##扩展原列表元素,输出结果:[1, 2, 3, 11, 22]
#与append的比较
name.append([11,22])
print(name)             ##追加列表元素,输出结果:[1, 2, 3,[11, 22]]

  6、index

name=[1,2,3]
print(name.index(1))    #获取当前元素的索引位置(左边优先)

  7、insert

name=[1,2,3]
name.insert(0,"czp")
print(name)             #插入,可指定插入元素的索引位置

  8、del、pop、remove

name=[1,2,3]
# name.pop(1)
# print(name)          #删除,可指定索引位置删除元素,默认是最后一个
# #----------------------------------------------------------------------------------
# name.remove(3)
# print(name)          #删除,remove方法中需要指定删除的元素,如果元素不在该列表中,则会报错
#----------------------------------------------------------------------------------
print(name)
del name[1]
print(name)             #删除,通过直接添加索引位置的方式

  9、reserve

name=[1,2,3]
name.reverse()
print(name)         #反转,将列表中的元素从最后一个元素开始输出

  10、sort

name=[2,1,3]
name.sort()
print(name)         #排序,后面会讲到和sorted的区别

   11、字符串与列表之间的相互转化

  将字符串转换成列表,可以理解为将字符串中的每一个字符进行一个for循环,每一个字符作为一个元素放置于列表中,如

name="czp"
l=list(name)
print(l)
输出结果:
[c, z, p]

  而如果将列表转化为字符串,就需要自己些for循环来完成这一需求,对于既有数字,又有字符的,如下:

name=["c","z","p",11]
s=""
for i in name:
   s=s+str(i)
   print(s)
输出结果:
czp11

  对于只有字符串的,可以更简便的通过jion方法来实现,如下:

name=["c","z","p","11"]
print("".join(name))
输出结果同样为:czp11

 

二:元组(tuple)

  元组其实就是不可变列表,一旦创建,便不能更改,元组的创建方式使用()的方式,如下

name=(1,2,3,)
print(type(name))               输出结果为<class ‘tuple‘>

  元组的方法就很少了,只有两个,一个index和count,用法和列表的用法一样,在这里就不重复介绍了。

  在创建元组的时候,推荐在最后一位元素后加上个“,”,以便于区分。另:元组是有序的

三:字典(dict)

  字典就是一种key-value对的形式,字典是无序的,因为字典中的key必须是唯一的,所示字典这种数据类型可以理解为是自动去重的,字典的value可以是任意值,字符串,数字,列表,字典等等。布尔值、列表、字典不可以作为字典的key

  字典的定义方式用 {} 来表示,如下:

name={
    "zhao":11,
    "qian":12,
    "sun":13,
}                                 可以看到,字典中都是key-value对的形式

  字典这种数据类型常用的方法有:

  1.clear() 

print(name.clear())       清除字典中的数据,输出结果为none

  2.fromkeys()

print(name.fromkeys(["c","z","p"],100))   创建字典,通过列表的方式指定多个key,并将这些key赋予相同的值
输出结果为:
{c: 100, z: 100, p: 100}

  3.get()

# v = dic[‘k11111‘]
# print(v)
# v = dic.get(‘k1‘,111111)
# print(v)                        根据Key获取值,key不存在时,可以指定默认值(None)

  4.pop

name={
    "k1":"v1",
    "k2":"v2"
}
name.pop("k1")                //删除,指定删除的key,如果存在,删除,如果key不存在,报错
print(name)                
输出结果:
{k2: v2}

  5.popitem

dic={
    "k1":"v1",
    "k2":"v2"
}
print(dic.popitem())          Python 字典 popitem() 方法随机返回并删除字典中的一对键和值(一般删除末尾对)。如果字典已经为空,却调用了此方法,就报出KeyError异常
输出结果:
{‘k2‘: ‘v2‘}           

  6.update

dic = {
    "k1": v1,
    "k2": v2
}
dic.update({k1: 111111})                        更新
print(dic)
运行结果:
{k1: 111111, k2: v2}

  字典的for循环

for i in dic.keys():                     输出字典中所有key的值
    print(i)
for i in dic.values():           输出字典中所有value的值
    print(i)
for k,v in dic.items():           输出字典中所有的key对应的value值
    print(k,v)

  列表、元组、字典都可以通过切片的方式进行增删改查。

 

以上是关于Pyhton编程之基本数据类型-列表元组字典的主要内容,如果未能解决你的问题,请参考以下文章

第八篇基本数据类型之列表元组与字典

Python全栈自动化系列之Python编程基础(列表元组字典)

python特色_字典,元组,列表

python基础小结

Python基础之基本数据类型的总结

Python 基础之集合及基本数据类型总结