Python字典(dict)
字典是另一种可变容器模型,且可存储任意类型对象。
字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号{}中:
>>> names_info = {"name":"Jack","age":"28","job":"IT"}
>>> names_info
{'age': '28', 'job': 'IT', 'name': 'Jack'}
注:
键(key)必须是唯一的,但值(value)则不必。
值(value)可以取任何数据类型,但键必须是不可变的,如字符串,数字或元组。
字典值可以没有限制地取任何python对象,既可以是标准的对象,也可以是用户定义的,但键不行。
两个重要的点需要记住:
1. 不允许同一个键出现两次。创建时如果同一个键被赋值两次,后一个值会被记住。
2. 键必须不可变,所以可以用数字,字符串或元组充当,而用列表就不行。
字典的操作:
查看字典有哪些方法:
>>> a = {"a":1,"b":123}
>>> dir(a)
['__class__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'clear', 'copy', 'fromkeys', 'get', 'items', 'keys', 'pop', 'popitem', 'setdefault', 'update', 'values']
1.定义字典值:
>>> names_info = {"name":"Jack","age":"28","job":"IT"}
>>> names_info
{'age': '28', 'job': 'IT', 'name': 'Jack'}
2.访问字典里的值:
>>> names_info
{'age': '28', 'job': 'IT', 'name': 'Jack'}
>>> names_info["name"]
'Jack'
>>> names_info["age"]
'28'
3.访问错误的key时(提示KeyError):
>>> names_info["agex"]
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
KeyError: 'agex'
4.修改字典的值,以及添加新的建值对;
>>> names_info["age"] = 30
>>> names_info["age"]
30
>>> names_info["gongzi"] = 5000
>>> names_info
{'age': 30, 'gongzi': 5000, 'job': 'IT', 'name': 'Jack'}
5.删除字典指定元素及清空字典所有元素。
>>> names_info
{'age': 30, 'gongzi': 5000, 'job': 'IT', 'name': 'Jack'}
>>> del names_info["gongzi"]
>>> names_info
{'age': 30, 'job': 'IT', 'name': 'Jack'}
>>> names_info.clear()
>>> names_info
{}
字典内置函数&方法
以下为内置函数:
序号 | 函数及描述 | 实例 |
---|---|---|
1 | len(dict)计算字典元素个数,即键(key)的总数 | >>> len(names_info) 4 |
2 | str(dict) 输出字典以可打印的字符串表示(双引号,引起来) | >>> str(names_info) "{'age': 30, 'name': 'Jack', 'gongzi': 5000, 'job': 'IT'}" |
3 | type(variable)返回输入的变量类型,如果变量是字典就返回字典类型(dict) | >>> type(names_info) <class 'dict'> |
以下为内置方法:
1.用于删除字典内所有元素; clear()
>>> names_info
{'age': 30, 'name': 'Jack', 'gongzi': 5000, 'job': 'IT'}
>>> names_info.clear()
>>> names_info
{}
2.返回一个字典的浅复制(只会复制第一层,如果值包含列表或列表或字典,修改此内容会一同变化);copy()
>>> names_info = {'age': 30, 'gongzi': 5000, 'job': 'IT', 'name': 'Jack'}
>>> names_info1 = names_info.copy()
>>> names_info1
{'age': 30, 'name': 'Jack', 'gongzi': 5000, 'job': 'IT'}
3.创建一个新字典,以序列seq中元素做字典的键,value为字典所有键对应的初始值;fromkeys()
>>> seq = ('name', 'age', 'sex')
>>> dict = dict.fromkeys(seq)
>>> print ("新的字典为 : %s" % str(dict))
新的字典为 : {'age': None, 'name': None, 'sex': None}
>>>
>>> dict = dict.fromkeys(seq, 10)
>>> print ("新的字典为 : %s" % str(dict))
新的字典为 : {'age': 10, 'name': 10, 'sex': 10}
4.请求函数返回指定的键的值,如果存在返回值,如果不存在返回默认指定值;get()
>>> names_info
{'age': 30, 'name': 'Jack', 'gongzi': 5000, 'job': 'IT'}
>>> names_info.get("sex","指定值")
'指定值'
>>> names_info.get("age","指定值")
30
5.判断键是否存在于字典中,如果键在字典dict里返回true,否则返回false; in
>>> names_info = {'age': 30, 'gongzi': 10000, 'aihao': 'nv', 'name': 'Jack', 'job': 'IT'}
>>> if "age" in names_info:
... print("age is %s"% names_info["age"])
... else:
... print("not in age")
...
age is 30
>>> if "sex" in names_info:
... print("sex is %s"% names_info["sex"])
... else:
... print("not in sex")
...
not in sex
6.以列表返回可遍历的(键, 值) 元组数组;items()
>>> names_info
{'age': 30, 'name': 'Jack', 'gongzi': 5000, 'job': 'IT'}
>>> names_info.items()
dict_items([('age', 30), ('name', 'Jack'), ('gongzi', 5000), ('job', 'IT')])
7.以列表形式返回一个字典所有的键;keys()
>>> names_info
{'age': 30, 'name': 'Jack', 'gongzi': 5000, 'job': 'IT'}
>>> names_info.keys()
dict_keys(['age', 'name', 'gongzi', 'job'])
8.setdefault() 方法和get()方法类似, 如果键不已经存在于字典中,将会添加键并将值设为默认值。
>>> names_info
{'age': 30, 'name': 'Jack', 'gongzi': 5000, 'job': 'IT'}
>>> names_info.setdefault("age",28)
30
>>> names_info
{'age': 30, 'name': 'Jack', 'gongzi': 5000, 'job': 'IT'}
>>> names_info.setdefault("sex","nv")
'nv'
>>> names_info
{'age': 30, 'name': 'Jack', 'sex': 'nv', 'gongzi': 5000, 'job': 'IT'}
9.函数把字典2的键/值对更新到字典1里;如果存在相同的key使用字典2更新字典1,如果不存在则添加到字典1中;
>>> names_info
{'age': 30, 'name': 'Jack', 'gongzi': 5000, 'job': 'IT'}
>>> a2
{'aihao': 'nv', 'sex': 'nv', 'gongzi': 10000}
>>> names_info.update(a2)
>>> names_info
{'age': 30, 'gongzi': 10000, 'aihao': 'nv', 'name': 'Jack', 'sex': 'nv', 'job': 'IT'}
10.以列表形式返回字典中的所有值value;values()
>>> names_info
{'age': 30, 'gongzi': 10000, 'aihao': 'nv', 'name': 'Jack', 'sex': 'nv', 'job': 'IT'}
>>> names_info.values()
dict_values([30, 10000, 'nv', 'Jack', 'nv', 'IT'])
>>> list(names_info.values())
[30, 10000, 'nv', 'Jack', 'nv', 'IT']
11.依照索引id形式取出字典中值:
a = [{'ip': '1.1.1.1'}, {'ip': '1.1.1.2'}, {'ip': '1.1.1.3'}]
b = [i['ip'] for i in a]
for i in range(len(b)):
print(i, b[i])
输出:
0 1.1.1.1
1 1.1.1.2
2 1.1.1.3
12.将两个字符串通过拉链(一 一对应)方式,组成字典;
title = "id,name,age,phone,dept,enrooll_data"
line = "28,李保林,19,13713731732,It,2017-08-08"
dic = dict(zip(title.split(","), line.split(",")))
print(dic)
输出:
{'enrooll_data': '2017-08-08', 'id': '28', 'phone': '13713731732', 'name': '李保林', 'age': '19', 'dept': 'It'}
13.将字典写入mysql中
desc_file = {'ymd_time': '20201210',
'event_time': 1607529600,
'mini_kadun': 1.1,
'mini_open': 91.1,
'mini_open_pv': 12229,
'mini_play_pv': 11431,
'mini_succ': 91.1,
'h5_kadun': 11.10,
'h5_open': 31.17,
'h5_succ': 71.19,
'h5_open_pv': 21114,
'h5_play_pv': 11111}
import pymysql
db = pymysql.connect(host="192.168.1.1", port=3306, user="baolin", passwd="123456", db="DB_name")
cursor = db.cursor()
qmarks = ', '.join(['%s'] * len(desc_file))
columns = ', '.join(desc_file.keys())
print("aaaa",qmarks)
print("bbbbb",columns)
# print(desc_file.values())
try:
# 表名为minih5
qry = "Insert Into minih5 (%s) Values (%s);" % (columns, qmarks)
cursor.execute(qry, list(desc_file.values()))
db.commit()
except Exception as e:
print(e)
输出:
aaaa %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s
bbbbb ymd_time, event_time, mini_kadun, mini_open, mini_open_pv, mini_play_pv, mini_succ, h5_kadun, h5_open, h5_succ, h5_open_pv, h5_play_pv