成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

使用Python對數(shù)據(jù)進行操作轉(zhuǎn)換

開發(fā) 后端
我們首先定義一個列表 MyList,接著,我們使用字典推導(dǎo)式,創(chuàng)建一個新的字典 MyDict,其中字典的鍵是從列表 MyList 中獲取的每個元素,而對應(yīng)的值都設(shè)置為 None。

1、列表加值轉(zhuǎn)字典

在Python中,將列表的值轉(zhuǎn)換為字典的鍵可以使用以下代碼:

#!/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,接著,我們使用字典推導(dǎo)式,創(chuàng)建一個新的字典 myDict,其中字典的鍵是從列表 myList 中獲取的每個元素,而對應(yīng)的值都設(shè)置為 None。

如果想讓列表中的值對應(yīng)不同的值,只需在推導(dǎo)式中指定相應(yīng)的值即可,例如:

#!/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'}

在上面的代碼中,我們創(chuàng)建一個包含鍵、值的列表,然后使用循環(huán)和字典推導(dǎo)式來創(chuàng)建字典,其中列表中的每個值對應(yīng)于字典中的一個鍵和一個值。

2、字典鍵新增值數(shù)據(jù)

根據(jù)上面的代碼,對每個鍵又新增了2條數(shù)據(jù),該如何操作。

如果想要在已經(jīng)存在的字典中為每個鍵添加多個值,可以將值存儲在列表中,然后將列表作為鍵對應(yīng)的值,例如:

#!/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、轉(zhuǎn)換新的字典格式

如何將[{'key': 'name', 'value': 'John'}, {'key': 'location', 'value': 'Bei Jing'}]數(shù)據(jù)更改為{'name': 'John', 'location': 'Bei Jing'}

可以使用一個循環(huán)來遍歷列表中的字典,然后將每個字典的鍵和值提取出來,組成一個新的字典。具體如下:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# 公眾號:AllTests軟件測試

# 原始數(shù)據(jù)
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,用于存儲新的數(shù)據(jù)。然后使用 for 循環(huán)遍歷原始數(shù)據(jù)中的每個字典。在循環(huán)中,使用 item['key'] 和 item['value'] 分別獲取當(dāng)前字典的鍵和值,并使用 new_dict[key] = value 將其存儲到新的字典中,最后輸出新的字典即可。

4、兩組數(shù)據(jù)比較篩選

有兩組數(shù)據(jù),list1['code', 'data.totalPage', 'data.type']和list2['code', 'description', 'errCode', 'error', 'msg', 'message', 'success', 'btSuccess', 'btCode', 'btMsg', 'header.mss'],篩選list1里面的元素不存在list2里,則預(yù)期的篩選結(jié)果為['data.totalPage', 'data.type']。

可以使用列表推導(dǎo)式以及not in語句來實現(xiàn)篩選:

#!/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']

其中,列表推導(dǎo)式的語法格式為:[返回值 for in 條件語句],它可以將符合條件的元素一次性生成到一個新列表中。而not in語句則表示不在列表中的元素。因此,上述代碼中的列表推導(dǎo)式就是遍歷list1中的每個元素ele,如果ele不在list2中,則將其添加到結(jié)果列表中。

5、將兩段獨立代碼合并

有兩段獨立的代碼,都有for循環(huán)。

hj = HandleJson(data_dict)
res = hj.find_key_path('request')
print(res)
print(type(res))
# request-循環(huán)
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-循環(huán)
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()函數(shù)將兩個循環(huán)的結(jié)果壓縮在一起,然后在一個for循環(huán)中同時遍歷兩個列表。具體代碼如下所示:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# 公眾號:AllTests軟件測試

hj = HandleJson(data_dict)
res = hj.find_key_path('request')
res2 = hj.find_key_path('response')
for count_i, (api_i, api_i2) in enumerate(zip(res, res2)):
    # request-循環(huán)的代碼內(nèi)容
    # response-循環(huán)的代碼內(nèi)容
責(zé)任編輯:姜華 來源: 今日頭條
相關(guān)推薦

2022-08-02 09:32:47

pandas移動計算

2021-08-09 15:00:36

SQL數(shù)據(jù)庫

2017-05-08 15:47:06

2021-10-22 06:53:45

脫敏處理數(shù)據(jù)

2010-07-22 17:25:23

2009-09-08 16:50:12

使用LINQ進行數(shù)據(jù)轉(zhuǎn)

2020-07-08 15:10:11

Python數(shù)據(jù)分析代碼

2009-09-28 09:47:55

Hibernate數(shù)據(jù)

2010-11-12 14:16:21

SQL游標(biāo)

2010-06-13 15:49:07

IP協(xié)議數(shù)據(jù)報

2018-04-16 12:14:34

數(shù)據(jù)科學(xué)機器學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)

2009-05-13 09:39:00

數(shù)據(jù)中心網(wǎng)絡(luò)設(shè)備管理

2009-07-29 17:27:23

數(shù)據(jù)中心CMDBIT

2014-04-03 13:11:07

數(shù)據(jù)中心雅虎

2018-04-25 13:32:31

數(shù)據(jù)保護GDPRCommvault

2022-11-02 14:45:24

Python數(shù)據(jù)分析工具

2009-07-16 14:46:48

jdbc statem

2022-04-08 11:25:58

數(shù)據(jù)庫操作AbilityData

2023-11-04 15:46:03

GORMGo

2024-11-13 15:22:36

Python列表切片
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 日本人做爰大片免费观看一老师 | 国产精品久久久久久久久久尿 | 欧美一区二不卡视频 | 日本不卡视频在线播放 | 国产一级精品毛片 | 精品一区二区三区在线视频 | 国产精品久久一区二区三区 | 欧美日韩成人网 | 日韩美女一区二区三区在线观看 | 免费黄色的视频 | 亚洲啪啪 | 色婷婷激情 | 91精品国产综合久久久久蜜臀 | 久久伊人在 | aa级毛片毛片免费观看久 | 久久一视频 | 一区二区三区四区五区在线视频 | 免费激情 | 在线免费观看毛片 | 超碰在线97国产 | 久久久国产一区二区三区四区小说 | 国产精品有限公司 | 国产精品美女www爽爽爽视频 | 欧美在线一区二区视频 | 欧美成人精品一区二区男人看 | 人人九九 | 精品91久久 | 亚洲欧美日韩在线不卡 | 亚洲深夜福利 | 97在线观视频免费观看 | 久久蜜桃av一区二区天堂 | 91久色 | 少妇特黄a一区二区三区88av | 伦理午夜电影免费观看 | 日本特黄特色aaa大片免费 | 国产高清一区二区三区 | 久久天天躁狠狠躁夜夜躁2014 | 99综合网| 亚洲视频在线免费 | 亚洲综合视频 | 极品的亚洲 |