成人视屏在线观看-国产99精品-国产精品1区2区-欧美一级在线观看-国产一区二区日韩-色九九九

您的位置:首頁技術文章
文章詳情頁

Python 把兩層列表展開平鋪成一層(5種實現方式)

瀏覽:4日期:2022-06-23 10:18:25

這幾天和同事在討論,如何用 Python 寫出優雅的讓列表中的列表展開,變成扁平化的列表。

例如

# 期望輸入input = [[(’A’, 1), (’B’, 2)], [(’C’, 3), (’D’, 4)]] # 期望輸出output = [(’A’, 1), (’B’, 2), (’C’, 3), (’D’, 4)]map 函數合并

>>> new = []; map(new.extend, input); new[None, None][(’A’, 1), (’B’, 2), (’C’, 3), (’D’, 4)]

這個方法看上去還可以,但是有個致命的缺點,就是map函數會返回值,并且這個返回值是沒有用的。另外還需要提前聲明一個變量,從代碼的簡潔性上,不夠簡潔優雅。

sum 函數合并

>>> sum(input, [])[(’A’, 1), (’B’, 2), (’C’, 3), (’D’, 4)]

這個看上去很簡潔,不過有類似字符串累加的性能陷阱。后面有性能對比。

reduce 函數

>>> reduce(list.__add__, input)[(’A’, 1), (’B’, 2), (’C’, 3), (’D’, 4)]

做序列的累加操作。也是有累加的性能陷阱。

列表推導式

>>> [item for sublist in input for item in sublist][(’A’, 1), (’B’, 2), (’C’, 3), (’D’, 4)]

列表推導式,看著有些長,而且還要for循環兩次,變成一行理解需要費勁一些,沒有那么直觀。

itertools 類庫

>>> list(itertools.chain(*input))[(’A’, 1), (’B’, 2), (’C’, 3), (’D’, 4)]

通過第三方類庫類實現的,相比其他的幾個實現,看著還算比較優雅。最后的性能發現居然還很高。

性能大對比

python -mtimeit -s’l=[[1,2,3],[4,5,6], [7], [8,9]]*99’ ’reduce(list.__add__,l)’1000 loops, best of 3: 547 usec per looppython -mtimeit -s’l=[[1,2,3],[4,5,6], [7], [8,9]]*99’ ’sum(l, [])’1000 loops, best of 3: 509 usec per looppython -mtimeit -s’l=[[1,2,3],[4,5,6], [7], [8,9]]*99’ ’[item for sublist in l for item in sublist]’10000 loops, best of 3: 52.8 usec per looppython -mtimeit -s’l=[[1,2,3],[4,5,6], [7], [8,9]]*99; import itertools;’ ’list(itertools.chain(*l))’10000 loops, best of 3: 35.9 usec per looppython -mtimeit -s’l=[[1,2,3],[4,5,6], [7], [8,9]]*99’ ’new = []; map(new.extend, l); new’10000 loops, best of 3: 34.1 usec per loop

歡迎大家共同探討優雅的的實現和性能的優化。

補充:python 將(含嵌套的)dict平鋪展開

話不多說,直接上代碼:

def prefix_dict(di_, prefix_s=’’): ''' 把字典的每個key都帶上前綴prefix_s :param di_: :param prefix_s: :return: ''' return {prefix_s + k: v for k, v in di_.items()} def spear_dict(di_, con_s=’.’): ''' 展開dict(如果下層還是dict),需要遞歸,展開到下層的數據類型不是字典為止 可能實用的地方:將文檔類的數據格式化成更加關系化的樣子可能有用 :param di_: 輸入字典 :param con_s: 層級間的連接符號 :return: 深度不大于1的字典,嵌套的其他數據類型照舊 ''' ret_di = {} for k, v in di_.items(): if type(v) is dict: v = spear_dict(v) # 這里或許有不寫到這一層的更好寫法 # for k_, v_ in v.items(): # ret_di.update({con_s.join([k, k_]): v_}) ret_di.update(prefix_dict(v, prefix_s=k + con_s)) else: ret_di.update({k: v}) return ret_di

>>> di_{’title’: ’新田商業街’, ’reliability’: 7, ’addressComponents’: {’streetNumber’: ’’, ’city’: ’深圳市’, ’street’: ’’, ’province’: ’廣東省’, ’district’: ’龍華區’}, ’location’: {’lng’: 114.09127044677734, ’lat’: 22.700519561767578}, ’adInfo’: {’adcode’: ’440309’}, ’level’: 11, ’more_deep’: {’loca’: {’lng’: 114.09127044677734, ’lat’: 22.700519561767578}}}>>> spear_dict(di_){’title’: ’新田商業街’, ’reliability’: 7, ’addressComponents.streetNumber’: ’’, ’addressComponents.city’: ’深圳市’, ’addressComponents.street’: ’’, ’addressComponents.province’: ’廣東省’, ’addressComponents.district’: ’龍華區’, ’location.lng’: 114.09127044677734, ’location.lat’: 22.700519561767578, ’adInfo.adcode’: ’440309’, ’level’: 11, ’more_deep.loca.lng’: 114.09127044677734, ’more_deep.loca.lat’: 22.700519561767578}spear_dict(di_, ’_’){’title’: ’新田商業街’, ’reliability’: 7, ’addressComponents_streetNumber’: ’’, ’addressComponents_city’: ’深圳市’, ’addressComponents_street’: ’’, ’addressComponents_province’: ’廣東省’, ’addressComponents_district’: ’龍華區’, ’location_lng’: 114.09127044677734, ’location_lat’: 22.700519561767578, ’adInfo_adcode’: ’440309’, ’level’: 11, ’more_deep_loca.lng’: 114.09127044677734, ’more_deep_loca.lat’: 22.700519561767578}

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 久久成人免费播放网站 | 国产理论最新国产精品视频 | 国产精品亚洲精品 | 成人看片黄a免费看视频 | 久久久综合结合狠狠狠97色 | 亚洲视频在线观看视频 | 国产成人无精品久久久久国语 | 永久免费毛片在线播放 | 免费一级欧美大片久久网 | 亚洲免费在线播放 | 国产欧美一区二区三区免费 | 一级一片免费看 | 国产成人综合怡春院精品 | 亚洲精品国产综合99久久一区 | 特黄特级a级黄毛片免费观看多人 | 亚洲欧美日韩三级 | 国产高清在线精品 | 激情欧美日韩一区二区 | 久久综合成人网 | 日韩欧美一二区 | 久综合 | 99这里只有精品视频 | 在线a亚洲视频播放在线观看 | 一本综合久久国产二区 | 特黄大片aaaaa毛片 | 自拍自录videosfree自拍自录 | 91黑丝国产线观看免费 | 日韩美一区二区 | 日韩亚洲欧美一区噜噜噜 | 国内外成人免费视频 | 国内国外精品一区二区 | 亚洲一区欧美二区 | 和日本免费不卡在线v | 在线免费看一级片 | 久久国产情侣 | 亚洲国产精品一区二区三区久久 | 扒开两腿猛进入爽爽视频 | 久草.com| 亚洲自拍图片区 | 亚洲精品中文字幕字幕 | 日韩精品永久免费播放平台 |