Python基础知识:字典
1、字典中键-值为一对,keys()返回一个列表,包含字典中所有键,values()返回所有值
favorite_languages ={
'jack':"python",
'alex':"c",
'james':"ruby"
}
for key in favorite_languages.keys():
print(key)
print(list(favorite_languages.keys()))
for value in favorite_languages.values():
print(value)
print(list(favorite_languages.values()))
2、给字典添加键-值对
favorite_languages ={
'jack':"python",
'alex':"c",
'james':"ruby"
}
favorite_languages['paul']='c++'
favorite_languages['charlie']='c'
print('favorite_language is :'+str(favorite_languages['charlie']))
print(favorite_languages['paul'])
print("Paul's favorite_language is %s."%favorite_languages['paul'])
3、items()返回一个键—值对列表;
favorite_languages ={
'jack':"python",
'alex':"c",
'james':"ruby"
}
for k,v in favorite_languages.items():
print('\nK:'+k)
print('V:'+v)
4、keys()--键列表的应用
#遍历键列表
for key in favorite_languages.keys():
print('\n'+key.title())
#检查一个朋友是否在键列表中
friends=['jack','james']
for name in favorite_languages.keys():
print('\n'+name.title())
if name in friends:
print('Hi '+name.title()+',I see your favorite language is '+
favorite_languages[name].title() + '!')
else:
print(name.title(),',please take our poll.')
#按顺序遍历字典中所有键
for name in sorted(favorite_languages.keys()):
print(name.title())
5、set()集合的方式输出列表,集合中每个元素必须独一无二
#values()值列表应用
favorite_languages ={
'jack':"python",
'alex':"c",
'james':"c"
}
languages=[]
for language in set(favorite_languages.values()):
print(language.title())
languages.append(language)
print(languages)
6、嵌套:列表中嵌套字典
#将两个字典循环插入空列表30次
resumes=[]
for resume_number in range(30):
new_resume1={'name':'jack','age':'','living_city':'beijing'}
new_resume2={'name':'alex','age':'','living_city':'shanghai'}
resumes.append(new_resume1)
resumes.append(new_resume2)
for resume in resumes[:3]:
print(resume)#依次输出前三个字典
if resume['name'] == 'jack':#按条件修改字典中的值
resume['name']='james'
resume['age']=''
resume['living_city']='zhengzhou'
elif resume['name'] == 'alex':
resume['name']='paul'
resume['age']=''
resume['living_city']='shenzhen'
print(resume)#依次输出修改后的前三个字典
print('The number of new resumes is %s.'%str(len(resumes)))#输出列表长度
7、字典中嵌套列表
#字典的值为列表
favorite_flowers={
'jack':['rose','lily','peony'],
'alex':'lily',
'james':['lily','peony','tulip']
}
for name,flowers in favorite_flowers.items():#遍历字典
print('\n',len(flowers))#输出值的长度
if len(flowers) > 1:#如果长度大于1,就为列表
print(name.title()+"'s favorite flower are:")
for flower in flowers:
print('\t',flower.title())
else: #否则就是单个字符串
print(name.title()+"'s favorite flower is:")
print('\t',flowers[0].title())
8、字典中嵌套字典
#字典的值为字典
people={
'eric':{'name':'eric','age':'','location':'beijing'},
'james':{'name':'james','age':'','location':'shanghai'}
}
for person,info in people.items():#遍历字典
print('\nUsername:',person) #依次输出键
for k,v in info.items(): #遍历嵌套字典的键值对
print('%s:%s'%(k,v))
print('------------')
9、setdefault()--括号内的值可以是key活着key,value,如果字典中有key,输出对应的值,如果括号内的key不存在,就给字典添加一个key,value值默认为None;
这个函数尽量不要用,容易出错
user_info = {
'jack':'c',
'alex':'c++'
}
print(user_info.setdefault('jack'))
print(user_info.setdefault('james','python'))
print(user_info)
10、fromkeys()只是借用一个字典的格式来生成一个新的字典,不改变借用字典,这个函数尽量不要用
popitem() 随机删除字典中的键-值对;尽量不要用
user_info = {
'jack':'c',
'alex':'c++'
}
print(user_info.fromkeys([1,2,3,4],'aaaa'))
print(user_info)
print(user_info.popitem())#随机删除字典中的键-值对;尽量不要用
print(user_info)
11、update()根据新的字典更新老的字典,已存在的键值对,根据第二个字典改变,没有的就添加进来,一切以第二个为准
user_info = {
'jack':'c',
'alex':'c++'
}
user_info2 = {
'alex':'python',
'paul':'java'
}
user_info.update(user_info2)#update()根据新的字典更新老的字典
print(user_info)
12、dic.get(key)函数获取字典的value,如果key不存在,就返回None,不会报错,如果直接用dic[key]=value,如果字典为空,就会报错。
dic = {}
print(dic.get("key"))
#None
Python基础知识:字典的更多相关文章
- Python基础知识---字典
现在在实习期间,好久没用Python了,今天在做Java项目时用的HashMap让我联想到了Python中的字典,就写一些Python字典的知识吧,复习复习. 字典: key --> valu ...
- 1.13 Python基础知识 - 字典和集合
一.字典 字典是一组键-值对的数据结构.每个键对应一个值.在字典中,键不能重复.根据键可以查询到值.字典是键和值的映射关系 字典的定义: 字典通过花括号中用逗号分隔的元素(键-值.键-值对使用冒号分隔 ...
- Python基础知识(五)------字典
Python基础知识(四)------字典 字典 一丶什么是字典 dict关键字 , 以 {} 表示, 以key:value形式保存数据 ,每个逗号分隔 键: 必须是可哈希,(不可变的数据类型 ...
- Python开发【第二篇】:Python基础知识
Python基础知识 一.初识基本数据类型 类型: int(整型) 在32位机器上,整数的位数为32位,取值范围为-2**31-2**31-1,即-2147483648-2147483647 在64位 ...
- python 基础知识(一)
python 基础知识(一) 一.python发展介绍 Python的创始人为Guido van Rossum.1989年圣诞节期间,在阿姆斯特丹,Guido为了打发圣诞节的无趣,决心开发一个新的脚本 ...
- python 爬虫与数据可视化--python基础知识
摘要:偶然机会接触到python语音,感觉语法简单.功能强大,刚好朋友分享了一个网课<python 爬虫与数据可视化>,于是在工作与闲暇时间学习起来,并做如下课程笔记整理,整体大概分为4个 ...
- python基础知识小结-运维笔记
接触python已有一段时间了,下面针对python基础知识的使用做一完整梳理:1)避免‘\n’等特殊字符的两种方式: a)利用转义字符‘\’ b)利用原始字符‘r’ print r'c:\now' ...
- Python基础知识(五)
# -*- coding: utf-8 -*-# @Time : 2018-12-25 19:31# @Author : 三斤春药# @Email : zhou_wanchun@qq.com# @Fi ...
- Python 基础知识(一)
1.Python简介 1.1.Python介绍 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆(中文名字:龟叔)为了在阿姆斯特丹打发时 ...
- python基础知识部分练习大全
python基础知识部分练习大全 1.执行 Python 脚本的两种方式 答:1.>>python ../pyhton.py 2. >>python.py #必须在首行 ...
随机推荐
- 小程序flex容器
flex:默认:水平方向是主轴,垂直方向是交叉轴,分布在第四象限,项目时在主轴方向上排列, 排满之后在交叉轴方向上换行: 1.设置容器的属性 display:flex 通过设置坐标轴来设置项目的排列方 ...
- 选择排序——Selection Sort
基本思想: 在长度为N的无序数组中,第一次遍历n-1个数,找到最小的数值与第一个元素交换:第二次遍历n-2个数,找到最小的数值与第二个元素交换:...第n-1次遍历,找到最小的数值与第n-1个元素交换 ...
- java——IObufferedReader文件输入输出流
package com.jredu.ch02_lianxi; import java.io.BufferedReader;import java.io.BufferedWriter;import ja ...
- Android开发之漫漫长途 XVII——动画
该文章是一个系列文章,是本人在Android开发的漫漫长途上的一点感想和记录,我会尽量按照先易后难的顺序进行编写该系列.该系列引用了<Android开发艺术探索>以及<深入理解And ...
- 面试:C++不可继承类
面试中可能遇到让设计一个无法被继承的类.最简单的实现是将该类的构造函数设置为私有的,然后通过静态成员函数调用私有构造函数实例化对象,这样的类确实不可继承,但是使用起来非常不方便,必须使用静态成员实例化 ...
- Crypto++应用:非对称加密RSA
1,非对称加密RSA: (1)乙方生成两把密钥(公钥和私钥).公钥是公开的,任何人都可以获得,私钥则是保密的. (2)甲方获取乙方的公钥,然后用它对信息加密. (3)乙方得到加密后的信息,用私钥解密. ...
- 【Elasticsearch全文搜索引擎实战】之Head插件实践
简介 Elasticsearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口.Elasticsearch是用Java开发的,并作为Ap ...
- Redis缓存使用技巧
缓存能够有效加速应用的访问速度,同时可以降低后端负载,在应用架构中起着至关重要的作用,本文主要介绍缓存使用的一些技巧. 缓存更新策略 LRU/LFU/FIFO算法剔除 场景:数据一致性要求较低 原理: ...
- 利用Redis发布订阅完成tomcat集群下的消息通知
以下为个人想法,如果有说的不对的地方请各位大佬见谅! 这是博主的第一篇博客,可能排版以及一些描述有不合理的地方还请勿喷,希望大家尽可能的多给我这样的新人一些鼓励让我能在写博客的道路上走下去. 进入正题 ...
- MySQL学习(四) SQL连接查询
更多情况下,我们查询的数据来源于多张表,所有有必要了解一下MySQL中的连接查询. SQL中将连接查询分成四类:交叉连接,内连接,外连接和自然连接. 数据准备 student表 -- -------- ...