成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

【Python】對字典列表進行去重追加

[TOC]

創(chuàng)新互聯(lián)主要從事網(wǎng)站建設(shè)、網(wǎng)站設(shè)計、網(wǎng)頁設(shè)計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)呈貢,10多年網(wǎng)站建設(shè)經(jīng)驗,價格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):13518219792

目標(biāo)

現(xiàn)有字典列表

    # 
    A = [ {dict1}, {dict2} ]
    B = [ {dict3}, {dict2} ]
    C = [ {dict3},  {dict4} ]
    M = [A,B,C]
    X = []

將M去重后的字典放入列表X中,得到X = [{dict1}, {dict2},{dict3}, {dict4}]

難點

字典列表

大家可能一開始會想到使用set()函數(shù)轉(zhuǎn)化為集合,自動去重。但是集合是使用hash來計算并去重的,但是字典類型無法使用Hash計算。雖然可以使用類class或者命名元組namedtupe來替換字典,但是這次的場景是無法變更列表的產(chǎn)生源的。

列表無集合操作的方法

列表之間無法使用交并差(&,|,-)的方式的集合計算方法

思路

# json,性能差
data = set([json.dumps(d) for d in data])
data = [json.loads(d) for d in data]

#  這種方式只能對ABC生效,對M還需要再一次循環(huán),瑪法
sortedlist = []

for item in listwhichneedssorting:
    if item not in sortedlist:
        sortedlist.append(item)

# 這種縮短了兩行
for i in M:
    X.extend(filter(lamda s: s not in X, i)) 

# 使用extend()而不是append(),因為我們需要拼接的是字典列表,而不是列表的列表
# lamda s: s not in X, M 匿名函數(shù),對i中的元素是否在X中進行判斷
# filter() 對上面匿名函數(shù)中不滿足條件(即重復(fù)的字典)進行過濾,返回尚未添加到X中的字典元素列表
# 使用extend()進行追加到X中

應(yīng)用

主要是從neo4j中取出關(guān)系數(shù)據(jù),分離節(jié)點,連接的關(guān)系,并轉(zhuǎn)換為前端適用的數(shù)據(jù)返回

def get_nodes_relationships(graph_list=None, ret_format=None):
    """
    將將關(guān)系與節(jié)點分離到各自的列表中
    :param graph_list:
    :param ret_format:
    :return:
    """
    node_list = []
    relationship_list = []
    for i in map(lambda x: x.get('graph', None).get('nodes'), graph_list):
        node_list.extend(filter(lambda x: x not in node_list, i))
    for m in map(lambda y: y.get('graph', None).get('relationships', None), graph_list):
        relationship_list.extend(filter(lambda x: x not in relationship_list, m))
    # i和m都是由字典組成的列表,i為單字典列表,m為多字典列表,
    # 前端要求去重,這里使用函數(shù)式語句返回沒有在結(jié)果列表中出現(xiàn)的字典,然后使用extend()追加

    # 如果是面向d3,需要更改部分信息為d3適配
    if ret_format == 'd3':
        def to_d3(link):
            """
            面向d3框架更改關(guān)系的鍵名,增加節(jié)點的數(shù)字類型
            :param link: 關(guān)系
            :return: 更改后返回
            """
            # 使用推出鍵值對,重新推入的方式實現(xiàn)變更鍵名為前端可以識別的source
            link.update(source=link.pop('startNode'))
            # 使用推出鍵值對,重新推入的方式實現(xiàn)變更鍵名為前端可以識別的target
            link.update(target=link.pop('endNode'))
            value_map = {
                "meta_in": 1,
                "slave_of": 2,
                "shard_to": 3
            }
            link['value'] = value_map[link['type']]
            return link

        relationship_list = map(lambda x: to_d3(x), relationship_list)

    # 如果是面向echarts,需要更改部分信息為echarts適配
    if ret_format == 'echarts':
        def to_echarts(node=None, link=None):
            """
            echarts適配
            :param node: 單個節(jié)點
            :param link: 單個關(guān)系
            :return: 更改后的節(jié)點或者關(guān)系
            """
            if (node and link) or (node is None and link is None):
                print("fuck you")
                exit(1)
            if node:
                node['name'] = node['id']
                node['draggable'] = True
                node['category'] = node['labels'][0]
                del node['labels']
                # del node['properties']
                bom = node
            if link:
                # 使用推出鍵值對,重新推入的方式實現(xiàn)變更鍵名為前端可以識別的source
                link.update(source=link.pop('startNode'))
                # 使用推出鍵值對,重新推入的方式實現(xiàn)變更鍵名為前端可以識別的target
                link.update(target=link.pop('endNode'))
                link.update(category=link.pop('type'))
                del link['id']
                del link['properties']
                # del link['category']
                bom = link
            return bom
        node_list = map(lambda node: to_echarts(node), node_list)
        relationship_list = map(lambda relation: to_echarts(link=relation), relationship_list)

    # 為什么要用set而不是list來轉(zhuǎn)化map對象:
    #  1.去重
    #  2.減小對象大小,達到縮減內(nèi)存占用
    # 為什么還是用list而不是set?
    #  1.dict對象不能被hash計算
    ret = {"nodes": list(node_list), "links": list(relationship_list)}

    return ret

網(wǎng)站欄目:【Python】對字典列表進行去重追加
分享網(wǎng)址:http://jinyejixie.com/article12/pgsedc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設(shè)計公司、搜索引擎優(yōu)化、網(wǎng)站設(shè)計、微信小程序Google、手機網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計公司
正定县| 三都| 张掖市| 项城市| 辽宁省| 安塞县| 肇州县| 秭归县| 钟山县| 宜君县| 麻江县| 姚安县| 揭阳市| 安丘市| 绥芬河市| 淮阳县| 阿荣旗| 新河县| 轮台县| 梧州市| 扎兰屯市| 赤峰市| 南川市| 扎赉特旗| 曲水县| 武强县| 开封县| 镇坪县| 沁水县| 邓州市| 大理市| 清涧县| 道真| 溧阳市| 郑州市| 上思县| 绿春县| 合作市| 威信县| 云阳县| 万载县|