有如下数据类型

cars = ['鲁A32444', '鲁B12333', '京B8989M', '黑C49678', '黑C46555', '沪B25041', '黑C34567']
locations = {'沪': '上海', '京': '北京', '黑': '黑龙江', '鲁': '山东', '鄂': '湖北', '湘': '湖南'}

将其转化成数据类型

{'上海': 1, '北京': 1, '黑龙江': 3, '山东': 2}

思路:

1. 新建一个空字典

2. 循环列表cars,判断如果car对应的key是否在dic里面,如果在里面,按方式一处理;否则按方式二处理

根据上述思路,可以写出如下代码:

 dic = dict()
for car in cars:
if locations[car[0]] not in dic: # 如果car对应的key不在dic中,就设置初始值1
dic[locations[car[0]]] = 1
else:
dic[locations[car[0]]] += 1 # 如果不在dic中,就自加1
print(dic)

上述代码还可以进行简化

 dic = dict()
for car in cars:
# 找key,找到就返回值,找不到设置初始值
dic[locations[car[0]]] = dic.get(locations[car[0]], 0) + 1
print(dic)

上述代码可以抽象成一个模型:

1. 找到操作的容器,通常是要得到的某个数据类型

2. 找到要判断的元素,通常是列表的元素或字典的键

3. 找到要遍历的容器,这个容器通常是要判断元素的母体

3. 判断元素是否在容器里,如果在,执行操作一,通常是创建,设置初始值;如果不在,执行操作二,通常是根据元素对容器进行修改

这个模型可以应用在很多问题中,下面来看另外一个例子:

有如下列表
list3 = [
{"name": "Helen", "hobby": "抽烟"},
{"name": "Helen", "hobby": "喝酒"},
{"name": "Helen", "hobby": "烫头"},
{"name": "Tony", "hobby": "喊麦"},
{"name": "Tony", "hobby": "街舞"},
]
要将其转化成下面形式的列表
[{'name': 'Helen', 'hobby_list': ['抽烟', '喝酒', '烫头']}, {'name': 'Tony', 'hobby_list': ['喊麦', '街舞']}]

利用上面总结的模型,可以很容易地写出如下代码

 # 1. 要操作的容器: list4
# 2. 要判断的元素:"name"
# 3. 要遍历的容器:list3
# 3. 判断"name"是否在list4里面,在,把list3的hobby添加到list4的hobby_list里面;
# 不在,在list4里创建一个字典:"name"就设置为name,创建hobby_list并添加name对应的hobby list4 = []
for i in list3:
for j in list4:
if i["name"] == j["name"]:
j["hobby_list"].append(i["hobby"])
break
else:
list4.append({"name": i["name"], "hobby_list": [i["hobby"]]})
print(list4)

这里还有一种方法:构造字典,再生成列表,不过总的思路还是上面的模型

 dic = dict()        # 要操作的容器: dic
for i in list3: # 要遍历的容器list3
if i["name"] not in dic: # 要判断的元素i["name"]
dic[i["name"]] = {"name": i["name"], "hobby_list": [i["hobby"]]}
else:
dic[i["name"]]["hobby_list"].append(i["hobby"])
list4 = list(dic.values())
print(list4)

好了,到这里就结束了,以后往某个容器里添加元素时如果遇到无则创建,有则改变的情况就可以运用上述模型,绝对无往不利。

python练习实例2--------构造数据类型的更多相关文章

  1. pcapng文件的python解析实例以及抓包补遗

    为了弥补pcap文件的缺陷,让抓包文件可以容纳更多的信息,pcapng格式应运而生.关于它的介绍详见<PCAP Next Generation Dump File Format> 当前的w ...

  2. python基础——实例属性和类属性

    python基础——实例属性和类属性 由于Python是动态语言,根据类创建的实例可以任意绑定属性. 给实例绑定属性的方法是通过实例变量,或者通过self变量: class Student(objec ...

  3. python 发送邮件实例

    留言板回复作者邮件提醒 -----------2016-5-11 15:03:58-- source:python发送邮件实例

  4. 【原创】C++链表如何像Python List一样支持多种数据类型

    用过Python的码友都知道,Python中List支持多种数据类型,如下面代码所示链表li内的数据类型可以是整数,同时也可以是字符串,当然也可以是其他数据类型. 1: >>> li ...

  5. Python学习笔记:02数据类型

    Python 数据类型 python中标准的数据类型有 基础类型 整型(长整型) 浮点型 复数型 布尔型 序列类型 字符串 列表 元组 字典 整型 整型和长整型并不严格区分,整型int的表达范围和计算 ...

  6. python Cmd实例之网络爬虫应用

    python Cmd实例之网络爬虫应用 标签(空格分隔): python Cmd 爬虫 废话少说,直接上代码 # encoding=utf-8 import os import multiproces ...

  7. Python自动化开发-变量、数据类型和运算

    一.变量 变量定义:Variables are used to store infomation to referrenced and manipulated in a computer progra ...

  8. Python第三天 序列 数据类型 数值 字符串 列表 元组 字典

    Python第三天 序列  数据类型  数值  字符串  列表  元组  字典 数据类型数值字符串列表元组字典 序列序列:字符串.列表.元组序列的两个主要特点是索引操作符和切片操作符- 索引操作符让我 ...

  9. python入门(8)数据类型和变量

    python入门(8)数据类型和变量 数据类型 在Python中,能够直接处理的数据类型有以下几种: 整数 Python可以处理任意大小的整数,当然包括负整数,在程序中的表示方法和数学上的写法一模一样 ...

随机推荐

  1. Java中数组判断元素存在几种方式比较详解

    1. 通过将数组转换成List,然后使用List中的contains进行判断其是否存在 public static boolean useList(String[] arr,String contai ...

  2. poj 1733 Parity game(带权并查集+离散化)

    题目链接:http://poj.org/problem?id=1733 题目大意:有一个很长很长含有01的字符串,长度可达1000000000,首先告诉你字符串的长度n,再给一个m,表示给你m条信息, ...

  3. nodejs的某些api~(四)udp&dns

    今天记udp/数据报套接字和dns. udp UDP/数据报套接字 => require('dgram');dgram.createServer([type],[cb]);type:可以是'ud ...

  4. 编写高质量代码:改善Java程序的151个建议 --[98~105]

    建议的采用顺序是List中泛型顺序依次为T.?.Object (1).List是确定的某一个类型 List表示的是List集合中的元素都为T类型,具体类型在运行期决定:List<?>表示的 ...

  5. A1002. A+B for Polynomials

    This time, you are supposed to find A+B where A and B are two polynomials. Input Each input file con ...

  6. [SDOI2011]计算器(exgcd&BSGS)

    k=1:裸的快速幂k=2:xy=z+kp,直接exgcd,这个可以不用解释了,不懂的同学可以看代码 k=3:裸的BSGS 重点是k=3(BSGS学习)ax=b(mod p)求解这个同余方程只能求gcd ...

  7. Day7--Python--基础数据类型补充,集合,深浅拷贝

    一.基础数据类型补充 1.join() 把列表中的每一项(必须是字符串)用字符串拼接 与split()相反 lst = ["汪峰", "吴君如", " ...

  8. poj 2566"Bound Found"(尺取法)

    传送门 参考资料: [1]:http://www.voidcn.com/article/p-huucvank-dv.html 题意: 题意就是找一个连续的子区间,使它的和的绝对值最接近target. ...

  9. Deepin或者Ubuntu上永久配件navicat

    1.深度商店下载安装Navicat,期间可能会要求安装wine等. 2.安装完毕      终端环境下找到Navicat的安装目录       langzi@langzi-PC:~$ whereis ...

  10. 函数,参数数组params与数组参数,结构函数

    1.函数 static 返回值类型 函数名(形参1,形参2,...){        函数体;        return 返回值; } 无返回值,则static void 函数名(){ } stat ...