• 使用Python对数据的操作转换


    1、列表加值转字典

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

    1. myList = ["name", "age", "location"]
    2. myDict = {k: None for k in myList}
    3. print(myDict)

    输出:

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

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

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

    1. myList = ["name", "age", "location"]
    2. myValues = ["John", 22, "Bei Jing"]
    3. myDict = {myList[i]: myValues[i] for i in range(len(myList))}
    4. print(myDict)

    输出:

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

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

    2、字典键新增值数据

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

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

    1. myDict = {"name": ["John"], "age": [22], "location": ["Bei Jing"]}
    2. # 为 name 增加两个新值
    3. myDict["name"].extend(["Alice", "Bob"])
    4. print(myDict)
    5. # 为 age 和 location 增加两个新值
    6. myDict["age"].append(25)
    7. myDict["location"].extend(["Shang Hai", "Guang Zhou"])
    8. print(myDict)

    输出:

    1. {'name': ['John', 'Alice', 'Bob'], 'age': [22], 'location': ['Bei Jing']}
    2. {'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'}

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

    1. # 原始数据
    2. data = [{'key': 'name', 'value': 'John'}, {'key': 'location', 'value': 'Bei Jing'}]
    3. # 新的字典
    4. new_dict = {}
    5. for item in data:
    6. key = item['key']
    7. value = item['value']
    8. new_dict[key] = value
    9. 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语句来实现筛选:

    1. list1 = ['code', 'data.totalPage', 'data.type']
    2. list2 = ['code', 'description', 'errCode', 'error', 'msg', 'message', 'success', 'btSuccess', 'btCode', 'btMsg', 'header.mss']
    3. result = [ele for ele in list1 if ele not in list2]
    4. print(result)

    输出:

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

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

    5、将两段独立代码合并

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

    1. hj = HandleJson(data_dict)
    2. res = hj.find_key_path('request')
    3. print(res)
    4. print(type(res))
    5. # request-循环
    6. for count_i, api_i in enumerate(res):
    7. # request
    8. json_request = eval(str(data_dict) + api_i)
    9. # print("json_request " + str(json_request))
    10. # name
    11. json_name = eval(str(data_dict) + api_i.replace("request", "name"))
    12. print("count_i 第 " + str(count_i + 1) + " 个接口")
    13. print("json_name " + str(json_name))
    14. hj2 = HandleJson(data_dict)
    15. res2 = hj2.find_key_path('response')
    16. print(res2)
    17. print(type(res2))
    18. # response-循环
    19. for count_i, api_i in enumerate(res2):
    20. # response
    21. json_response = eval(str(data_dict) + api_i)
    22. print("json_response " + str(json_response))
    23. if json_response:
    24. print("json_response 不为空")
    25. for count_i_i, api_i_i in enumerate(json_response):
    26. # print(api_i_i)
    27. # name
    28. json_name = eval(str(api_i_i) + str(["name"]))
    29. print("count_i_i 第 " + str(count_i_i + 1) + " 个接口")
    30. print("json_name " + str(json_name))

    如何将这两段代码合并

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

    1. hj = HandleJson(data_dict)
    2. res = hj.find_key_path('request')
    3. res2 = hj.find_key_path('response')
    4. for count_i, (api_i, api_i2) in enumerate(zip(res, res2)):
    5. # request-循环的代码内容
    6. # response-循环的代码内容

    最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

    在这里插入图片描述

    软件测试面试小程序

    被百万人刷爆的软件测试题库!!!谁用谁知道!!!全网最全面试刷题小程序,手机就可以刷题,地铁上公交上,卷起来!

    涵盖以下这些面试题板块:

    1、软件测试基础理论 ,2、web,app,接口功能测试 ,3、网络 ,4、数据库 ,5、linux

    6、web,app,接口自动化 ,7、性能测试 ,8、编程基础,9、hr面试题 ,10、开放性测试题,11、安全测试,12、计算机基础

    这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!   

  • 相关阅读:
    SELinux零知识学习十七、SELinux策略语言之类型强制(2)
    阅读JavaScript文档-一些常用方法
    数据库插入数据
    Hudi DeltaStreamer使用总结
    Pytorch多GPU条件下DDP集群分布训练实现(简述-从无到有)
    IT运维:使用数据分析平台监控H3C交换机
    2.6 Python 基本数据类型
    你应该可以不用那么辛苦的赚钱?
    Python基础——下载安装、卸载和系统环境配置
    链接装载与库:第八章——Linux共享库组织
  • 原文地址:https://blog.csdn.net/qq_48811377/article/details/132667857