【数据分析】使用Python对数据的操作转换

使用Python对数据的操作转换

目录


1、列表加值转字典

2、字典键新增值数据

3、转换新的字典格式

4、两组数据比较筛选

5、将两段独立代码合并

1、列表加值转字典

在Python中,将列表的值转换为字典的键可以使用以下代码:

#!/usr/bin/env python  
# -*- coding: utf-8 -*-  
# 公众号:AllTests软件测试  
  
myList = ["name", "age", "location"]  
myDict = {k: None for k in myList}  
print(myDict)

输出:

{'name': None, 'age': None, 'location': None}

在上面的代码中,我们首先定义一个列表 myList,接着,我们使用字典推导式,创建一个新的字典 myDict,其中字典的键是从列表 myList 中获取的每个元素,而对应的值都设置为 None。

如果想让列表中的值对应不同的值,只需在推导式中指定相应的值即可,例如:

#!/usr/bin/env python  
# -*- coding: utf-8 -*-  
# 公众号:AllTests软件测试  
  
myList = ["name", "age", "location"]  
myValues = ["John", 22, "Bei Jing"]  
myDict = {myList[i]: myValues[i] for i in range(len(myList))}  
print(myDict)

输出:

{'name': 'John', 'age': 22, 'location': 'Bei Jing'}

在上面的代码中,我们创建一个包含键、值的列表,然后使用循环和字典推导式来创建字典,其中列表中的每个值对应于字典中的一个键和一个值。

2、字典键新增值数据

根据上面的代码,对每个键又新增了2条数据,该如何操作

如果想要在已经存在的字典中为每个键添加多个值,可以将值存储在列表中,然后将列表作为键对应的值,例如:

#!/usr/bin/env python  
# -*- coding: utf-8 -*-  
# 公众号:AllTests软件测试  
  
myDict = {"name": ["John"], "age": [22], "location": ["Bei Jing"]}  
  
# 为 name 增加两个新值  
myDict["name"].extend(["Alice", "Bob"])  
print(myDict)  
  
# 为 age 和 location 增加两个新值  
myDict["age"].append(25)  
myDict["location"].extend(["Shang Hai", "Guang Zhou"])  
print(myDict)

输出:

{'name': ['John', 'Alice', 'Bob'], 'age': [22], 'location': ['Bei Jing']}  
{'name': ['John', 'Alice', 'Bob'], 'age': [22, 25], 'location': ['Bei Jing', 'Shang Hai', 'Guang Zhou']}

在上面的代码中,我们首先在字典中为每个键初始化一个列表,然后可以使用字典键和列表方法来添加由多个值组成的列表。

3、转换新的字典格式

如何将[{‘key’: ‘name’, ‘value’: ‘John’}, {‘key’: ‘location’, ‘value’: ‘Bei Jing’}]数据更改为{‘name’: ‘John’, ‘location’: ‘Bei Jing’}

可以使用一个循环来遍历列表中的字典,然后将每个字典的键和值提取出来,组成一个新的字典。具体如下:

#!/usr/bin/env python  
# -*- coding: utf-8 -*-  
# 公众号:AllTests软件测试  
  
# 原始数据  
data = [{'key': 'name', 'value': 'John'}, {'key': 'location', 'value': 'Bei Jing'}]  
  
# 新的字典  
new_dict = {}  
for item in data:  
    key = item['key']  
    value = item['value']  
    new_dict[key] = value  
  
print(new_dict)

输出:

{'name': 'John', 'location': 'Bei Jing'}

首先定义一个空字典 new_dict,用于存储新的数据。然后使用 for 循环遍历原始数据中的每个字典。在循环中,使用 item[‘key’] 和 item[‘value’] 分别获取当前字典的键和值,并使用 new_dict[key] = value 将其存储到新的字典中,最后输出新的字典即可。

4、两组数据比较筛选

有两组数据,list1[‘code’, ‘data.totalPage’, ‘data.type’]和list2[‘code’, ‘description’, ‘errCode’, ‘error’, ‘msg’, ‘message’, ‘success’, ‘btSuccess’, ‘btCode’, ‘btMsg’, ‘header.mss’],筛选list1里面的元素不存在list2里,则预期的筛选结果为[‘data.totalPage’, ‘data.type’]

可以使用列表推导式以及not in语句来实现筛选:

#!/usr/bin/env python  
# -*- coding: utf-8 -*-  
# 公众号:AllTests软件测试  
  
list1 = ['code', 'data.totalPage', 'data.type']  
list2 = ['code', 'description', 'errCode', 'error', 'msg', 'message', 'success', 'btSuccess', 'btCode', 'btMsg', 'header.mss']  
  
result = [ele for ele in list1 if ele not in list2]  
print(result)

输出:

['data.totalPage', 'data.type']

其中,列表推导式的语法格式为:[返回值 for in 条件语句],它可以将符合条件的元素一次性生成到一个新列表中。而not in语句则表示不在列表中的元素。因此,上述代码中的列表推导式就是遍历list1中的每个元素ele,如果ele不在list2中,则将其添加到结果列表中。

5、将两段独立代码合并

有两段独立的代码,都有for循环

hj = HandleJson(data_dict)  
res = hj.find_key_path('request')  
print(res)  
print(type(res))  
# request-循环  
for count_i, api_i in enumerate(res):  
    # request  
    json_request = eval(str(data_dict) + api_i)  
    # print("json_request " + str(json_request))  
    # name  
    json_name = eval(str(data_dict) + api_i.replace("request", "name"))  
    print("count_i 第 " + str(count_i + 1) + " 个接口")  
    print("json_name " + str(json_name))  
  
hj2 = HandleJson(data_dict)  
res2 = hj2.find_key_path('response')  
print(res2)  
print(type(res2))  
# response-循环  
for count_i, api_i in enumerate(res2):  
    # response  
    json_response = eval(str(data_dict) + api_i)  
    print("json_response " + str(json_response))  
    if json_response:  
        print("json_response 不为空")  
        for count_i_i, api_i_i in enumerate(json_response):  
            # print(api_i_i)  
            # name  
            json_name = eval(str(api_i_i) + str(["name"]))  
            print("count_i_i 第 " + str(count_i_i + 1) + " 个接口")  
            print("json_name " + str(json_name))

如何将这两段代码合并

可以使用zip()函数将两个循环的结果压缩在一起,然后在一个for循环中同时遍历两个列表。具体代码如下所示:

---------------------------END---------------------------

题外话

当下这个大数据时代不掌握一门编程语言怎么跟的上脚本呢?当下最火的编程语言Python前景一片光明!如果你也想跟上时代提升自己那么请看一下.

在这里插入图片描述

感兴趣的小伙伴,赠送全套Python学习资料,包含面试题、简历资料等具体看下方。

👉CSDN大礼包🎁:全网最全《Python学习资料》免费赠送🆓!(安全链接,放心点击)

一、Python所有方向的学习路线

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照下面的知识点去找对应的学习资源,保证自己学得较为全面。

img
img

二、Python必备开发工具

工具都帮大家整理好了,安装就可直接上手!img

三、最新Python学习笔记

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。

img

四、Python视频合集

观看全面零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

img

五、实战案例

纸上得来终觉浅,要学会跟着视频一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。img

六、面试宝典

在这里插入图片描述

在这里插入图片描述

简历模板在这里插入图片描述

<img src=“https://i-blog.csdnimg.cn/blog_migrate/779f8463eafa0a97fd65dd85e54f149b.png”

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值