一、昨日内容回顾

1、 列表:

insert:按照指定下标插入
append:在列表最后增加
extend:迭代式的增加到列表的最后,相当于列表扩展  

pop:根据指定下标删除,返回删除的元素,如果元素不存在会报错
remove:根据元素名删除与之匹配的第一个元素,无返回值,如果不存在会报错
clear:清空列表
del:根据元素下标或切片的方式删除,也可以直接删除整个列表

改:

根据元素下标修改
根据切片修改(先删除切片指定的范围,然后在以迭代的方式插入到切片位置) 

根据元素下标查询
根据切片查询
根据循环查询

其他方法:

len:统计列表元素的总个数
conut:统计指定字符或字符串在列表中出现的元素个数
index:获取指定元素的下标,支持切片,若不存在会报错
sort:排序,默认是正序。(若sort的reverse属性为True时,进行倒序排序,默认revers的属性是False)
reserver:反转

2、元组:

元组又叫做只读列表
元组中的列表可以修改
元组中的元组也不能修改
元组支持切片

3、 range:

python2中使用xrange的方法,python3中使用range,两者使用方法一模一样。

4、join:按照指定的连接符把可迭代对象分隔开,不指定连接符默认无缝连接,可支持切片

name_list = ['yange', 'yy', 'li', 'yan', 'liyan', 'yy']
new_list1 = '-'.join(name_list)
new_list2 = '#'.join(name_list[1:4])
print(new_list1)
print(new_list2)
>>>
yange-yy-li-yan-liyan-yy
yy#li#yan

二、重点作业讲解

5,查找列表li中的元素,移除每个元素的空格,并找出以’A’或者’a’开头,并以’c’结尾的所有元素,并添加到一个新列表中,最后循环打印这个新列表。

方法一:
li = ['taibai ', 'alexC', 'AbC ', 'egon', ' Ritian', ' Wusir', '  aqc']
new_li = []
for i in li:
i = i.strip()
if i.lower().startswith('a') and i[-1] == 'c':
new_li.append(i)
print(new_li)
方法二:
li = ['taibai ','alexC','AbC ','egon',' Ritian',' Wusir','  aqc']
lis =[]
for i in li:
a =i.strip()
if a.startswith('A') or a.startswith('a') :
if a.endswith('c'):
lis.append(a)
else:
continue
print(lis)

6、开发敏感词语过滤程序,提示用户输入评论内容,如果用户输入的内容中包含特殊的字符:敏感词列表 li = ["苍老师","东京热",”武藤兰”,”波多野结衣”]则将用户输入的内容中的敏感词汇替换成***,并添加到一个列表中;如果用户输入的内容没有敏感词汇,则直接添加到上述的列表中。

将所有敏感词替换成'***'
info=input("请输入您的评论:")
li=["苍老师","东京热","武藤兰","波多野结衣"]
new_li=[]
for i in li:
if li.index(i)!=-1:
info=info.replace(i,"***")
l1=new_li.append(info)
print(new_li)

将所有敏感词替换成对应数量的*

li = ["苍老师","东京热","武藤兰","波多野结衣"]
new_li = []
info = input('请输入你的评论:')
for i in li:
if info.find(i) != -1:
l = len(i)
info = info.replace(i,'*'*l)
new_li.append(info)
print(new_li)

将所有敏感词替换成对应数量的*

info=input("请输入您的评论:")
li=["苍老师","东京热","武藤兰","波多野结衣"]
new_li=[]
for i in li:
if li.index(i)!=-1:
l = len(i)
info = info.replace(i,'*'*l)
l1=new_li.append(info)
print(new_li)

三、今日内容讲解

1、字典的描述:

字典是python中唯一的映射类型,采用键值对(key-value)的形式存储数据。python对key进行哈希函数运算,根据计算的结果决定value的存储地址,所以字典是无序存储的,且key必须是可哈希的。可哈希表示key必须是不可变类型,如:数字、字符串、元组。字典(dictionary)是除列表意外python之中最灵活的内置数据结构类型。列表是有序的对象结合,字典是无序的对象集合。两者之间的区别在于:字典当中的元素是通过键来存取的,而不是通过偏移存取。

2、字典的特点:

字典是python中唯一一个映射的数据类型
字典是无序的
字典的数据关联性强
字典是键值对存储方式
字典的key必须是可哈希hash的(不可变的数据类型)
字典的key必须是唯一的
字典天生去重
若字典的key重复时,后面的会覆盖前面的键值

3、字典的操作:

增:

直接指定键值添加,如果key已存在,则覆盖(或叫修改)
dict_insert = {
'name': 'liyan',
'age': 18,
'sex': 'man'
}
dict_insert['job'] = 'IT'
print(dict_insert)
dict_insert['age'] = 20
print(dict_insert)
>>>
{'name': 'liyan', 'age': 18, 'sex': 'man', 'job': 'IT'}
{'name': 'liyan', 'age': 20, 'sex': 'man', 'job': 'IT'} setdefault:指定键值对添加,如果不指定value,则值为none,如果所添加的key已存在,则不做任何操作 dict_insert = {
'name': 'liyan',
'age': 18,
'sex': 'man'
}
dict_insert.setdefault('job')
print(dict_insert)
dict_insert.setdefault('age', '20')
print(dict_insert)
>>>
{'name': 'liyan', 'age': 18, 'sex': 'man', 'job': None}
{'name': 'liyan', 'age': 18, 'sex': 'man', 'job': None}

删:

pop:根据键删除键值对,返回key所对应的value,如果key不存在会报错 ,报错信息可以自定义

  dict_delete = { 'name': 'liyan', 'age': 18, 'sex': 'man' }

  print(dict_delete.pop('sex'))

  print(dict_delete)

  print(dict_delete.pop('aaa', '返回这个'))

  print(dict_delete.pop('aaa'))

  >>> man {'name': 'liyan', 'age': 18}

  返回这个

  KeyError: 'aaa'

popitem:随机删除一组键值对,并返回删除的结果

  dict_delete = { 'name': 'liyan', 'age': 18, 'sex': 'man' }

  print(dict_delete.popitem())

  print(dict_delete)

  >>> ('sex', 'man')

  {'name': 'liyan', 'age': 18}

clear:清空字典

  dict_delete = { 'name': 'liyan', 'age': 18, 'sex': 'man' }

  print(dict_delete.clear())

  print(dict_delete)

  >>> None

   {}

del:根据键删除键值对,没有返回值,如果key不存在会报错

  dict_delete = { 'name': 'liyan', 'age': 18, 'sex': 'man' }

  del dict_delete['name']

  print(dict_delete)

  del dict_delete['aaa']

  print(dict_delete)

  >>> {'age': 18, 'sex': 'man'}

     KeyError: 'aaa'

改:

直接指定键和值修改,等同于新增已存在的key
dict_update = {
'name': 'liyan',
'age': 18,
'sex': 'man'
}
dict_update['age'] = 25
print(dict_update)
>>>
{'name': 'liyan', 'age': 25, 'sex': 'man'} update:把一个字典的键值对以覆盖的方式添加到另一个字典中(key存在时则覆盖,key不存在时则添加) dict_update1 = {
'name': 'liyan',
'age': 18,
'sex': 'man'
}
dict_update2 = {
'job': 'IT',
'name': 'yy'
}
print(dict_update1)
dict_update1.update(dict_update2)
print(dict_update1)
print(dict_update2)
dict_update2.update(dict_update1)
print(dict_update1)
print(dict_update2)
>>>
{'name': 'liyan', 'age': 18, 'sex': 'man'}
{'name': 'yy', 'age': 18, 'sex': 'man', 'job': 'IT'}
{'job': 'IT', 'name': 'yy'}
{'name': 'yy', 'age': 18, 'sex': 'man', 'job': 'IT'}
{'job': 'IT', 'name': 'yy', 'age': 18, 'sex': 'man'}

查:

根据键名查找对应的值,如果key不存在会报错
dict_select = {
'name': 'liyan',
'age': 18,
'sex': 'man'
}
print(dict_select['name'])
print(dict_select['aaa'])
>>>
liyan
KeyError: 'aaa' get:根据键名查找,如果key存在返回对应的value,如果key不存在则返回None,返回信息可以自定义 dict_select = {
'name': 'liyan',
'age': 18,
'sex': 'man'
}
print(dict_select.get('name'))
print(dict_select.get('aaa'))
print(dict_select.get('aaa', '找不到返回这个'))
>>>
liyan
None
找不到返回这个

其他操作:

keys:输出字典所有的key

dict_select = {
'name': 'liyan',
'age': 18,
'sex': 'man'
}
print(dict_select.keys(), type(dict_select.keys()))
>>>
dict_keys(['name', 'age', 'sex']) <class 'dict_keys'>
values:输出字典所有的value dict_select = {
'name': 'liyan',
'age': 18,
'sex': 'man'
}
print(dict_select.values(), type(dict_select.values()))
>>>
dict_values(['liyan', 18, 'man']) <class 'dict_values'>
items:把字典的每个键值对以元组的方式输出 dict_select = {
'name': 'liyan',
'age': 18,
'sex': 'man'
}
print(dict_select.items(),type(dict_select.items()))
>>>
dict_items([('name', 'liyan'), ('age', 18), ('sex', 'man')]) <class 'dict_items'>

python基础五--dict的更多相关文章

  1. python基础之dict、set及字符

    python基础之dict.set及字符串处理 本节内容 字典介绍及内置方法 集合介绍 字符串处理 1.字典介绍及内置方法 字典是python中唯一的映射类型,采用键值对(key-value)的形式存 ...

  2. python基础——使用dict和set

    python基础——使用dict和set dict Python内置了字典:dict的支持,dict全称dictionary,在其它语言中也称为map(映射),使用键-值(key-value)存储,具 ...

  3. 第四篇:python基础之dict、set及字符

    python基础之dict.set及字符   python基础之dict.set及字符串处理 本节内容 字典介绍及内置方法 集合介绍 字符串处理 1.字典介绍及内置方法 字典是python中唯一的映射 ...

  4. Python基础之dict和set的使用

    dict Python内置了字典:dict的支持,dict全称dictionary,在其他语言种也称为map,使用键-值(key-value)存储,具有极快的查找速度. 举个例子,假设要根据同学的名字 ...

  5. Python基础(五) python装饰器使用

    这是在Python学习小组上介绍的内容,现学现卖.多练习是好的学习方式. 第一步:最简单的函数,准备附加额外功能 # -*- coding:gbk -*- '''示例1: 最简单的函数,表示调用了两次 ...

  6. Python基础:字典(dict)与集合(set)

    查找场景下与列表的性能对比 字典与集合之所以高效的原因是:内部结构都是一张哈希表. 平均情况下插入.查找和删除的时间复杂度为 O(1). 假设有数量100,000的产品列表: import time ...

  7. Python - 基础数据类型 dict 字典

    字典简介 字典在 Python 里面是非常重要的数据类型,而且很常用 字典是以关键字(键)为索引,关键字(键)可以是任意不可变类型 字典由键和对应值成对组成,字典中所有的键值对放在 { } 中间,每一 ...

  8. python基础五

    列表生成式 将列表data=[1,2,3]里的元素都乘2 方法一 data=[1,2,3] for index,i in enumerate(data): data[index] *=2 print( ...

  9. python基础教程——dict和set

    dict python内置字典:dict,全称dictionary,在其他语言中称为map,使用键值对存储. ex: d = {'xiaoli' : 95 , 'xiaoming' : 98 , 'x ...

随机推荐

  1. 从UE(用户体验)到道家誓学再到李小龙

    公司大Boss经常会给我做技术培训,感觉他什么都知道,也挺喜欢听他的课. 本文记录可能比较天马行空,我的语文比较差,很难把自己想表达的说出来,为此我就是记录一样关键字,可能这样还会更好些 背景是讲用户 ...

  2. JavaScript ES6 规范

    ES6 简介 ECMAScript 6 简称 ES6,是 JavaScript 语言的下一代标准,已经在2015年6月正式发布了.它的目标是使得 JavaScript 语言可以用来编写复杂的大型应用程 ...

  3. MySQL升级方法一

    1.在目标服务器上安装新版本的mysql数据库. 1)解压缩新版mysql数据库压缩包并cp到指定目录: [root@faspdev mnt]# tar -zxvf mysql-5.6.24-linu ...

  4. 通过qemu复现路由器漏洞

    目录 简介 环境搭建 固件解包 复现漏洞,IDA调试 参考资料 简介 qemu和vmware一样,一种虚拟机软件,只不过qemu能够虚拟的平台更加丰富一些.能够虚拟很多嵌入式平台的设备. 工作上需要向 ...

  5. paas平台

    paas平台 定义:PaaS是云计算中重要的一类服务,为用户提供应用的全生命周期管理和相关的资源服务.通过PaaS,用户可以完成应用的构建.部署.运维管理,而不需要自己去搭建计算环境,如安装服务器.操 ...

  6. 启动spark

    cd /app/sparkuser/spark-120/sbin ./start-all.sh #./stop-all.sh #停止服务 -------------------

  7. javascript打开制定窗口大小的页面

    <a  onclick="window.open ('页面链接', 'newwindow', 'height=680, width=400, top=0, left=0, toolba ...

  8. redis 介绍

    缓存数据库介绍 NoSQL(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,泛指非关系型的数据库,随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站,特别是 ...

  9. mysql查看和修改注释

    MySQL查看注释,MySQL修改注释,mysql查看注释,mysql修改注释 1.给大家做演示,这里随便创建一张学生表,代码如下: CREATE TABLE `student` ( `id` int ...

  10. Kylin安装部署

    一.安装准备 1.操作系统 Centos 7.x 2.时间问题 集群内所有节点时间一定要同步. NTP.Chrony 3.用户 创建hadoop组和hadoop用户,并做ssh免密码登录 4.Hado ...