亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

python - 關于NumPy數組操作的問題

瀏覽:116日期:2022-06-26 18:57:18

問題描述

[’000001_2017-03-17.csv’, ’000001_2017-03-20.csv’, ’000002_2017-03-21.csv’, ’000002_2017-03-22.csv’, ’000003_2017-03-23.csv’, ’000004_2017-03-24.csv’]

numpy數組,總共有幾個萬個元素。現在想保留每個元素前面的編號000001之類的,并且去掉重復,只保留唯一的一個編號。結果應該是[’000001’,’000002’,’000003’,’000004’]除了用for語句實現外,有沒有更高效的辦法?

問題解答

回答1:

寫個NumPy的吧~

python3

>>> import numpy as np>>> a = np.array([’000001_2017-03-17.csv’, ’000001_2017-03-20.csv’, ’000002_2017-03-21.csv’, ’000002_2017-03-22.csv’, ’000003_2017-03-23.csv’, ’000004_2017-03-24.csv’])>>> b = np.unique(np.fromiter(map(lambda x:x.split(’_’)[0],a),’|S6’))>>> barray([b’000001’, b’000002’, b’000003’, b’000004’], dtype=’|S6’)

還可以這樣寫:np.frompyfunc’|S6’是以6個字節存儲字符串

’<U6’是以6個小端序Unicode字符存儲字符串

>>> b = np.array(np.unique(np.frompyfunc(lambda x:x[:6],1,1)(a)),dtype=’<U6’)>>> barray([’000001’, ’000002’, ’000003’, ’000004’], dtype=’<U6’)回答2:

綜合兩位仁兄的寫法@同意并接受 @xiaojieluoff

如果編號長度固定是前六位,最快的寫法下面第一種最快

import timelst = [’000001_2017-03-17.csv’, ’000001_2017-03-20.csv’, ’000002_2017-03-21.csv’, ’000002_2017-03-22.csv’, ’000003_2017-03-23.csv’, ’000004_2017-03-24.csv’] * 1000000start = time.time()data = {_[:6] for _ in lst}print ’dic: {}’.format(time.time() - start)start = time.time()data = set(_[:6] for _ in lst)print ’set: {}’.format(time.time() - start)start = time.time()data = set(map(lambda _: _[:6], lst))print(’map:{}’.format(time.time() - start))start = time.time()data = set()[data.add(_[:6]) for _ in lst]print(’for:{}’.format(time.time() - start))耗時:dic: 0.72798705101set: 0.929664850235map:1.89214396477for:1.76194214821回答3:

使用 map 和匿名函數

lists = [’000001_2017-03-17.csv’, ’000001_2017-03-20.csv’,’000002_2017-03-21.csv’,’000002_2017-03-22.csv’,’000003_2017-03-23.csv’, ’000004_2017-03-24.csv’]data = list(set(map(lambda x:x.split(’_’)[0], lists)))print(data)

輸出:

[’000003’, ’000004’, ’000001’, ’000002’]

運行下面代碼可以看到 , 在 6百萬 條數據下,map 比 for 快了 0.6s 左右

import timelists = [’000001_2017-03-17.csv’, ’000001_2017-03-20.csv’, ’000002_2017-03-21.csv’, ’000002_2017-03-22.csv’, ’000003_2017-03-23.csv’, ’000004_2017-03-24.csv’] * 1000000map_start = time.clock()map_data = list(set(map(lambda x:x.split(’_’)[0], lists)))map_end = (time.clock() - map_start)print(’map 運行時間:{}’.format(map_end))for_start = time.clock()data = set()for k in lists: data.add(k.split(’_’)[0])for_end = (time.clock() - for_start)print(’for 運行時間:{}’.format(for_end))

輸出:

map 運行時間:2.36173for 運行時間:2.9405870000000003

如果把測試數據擴大到 6千萬, 差距就更明顯了

map 運行時間:29.620203for 運行時間:33.132621

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 亚洲一区二区三区高清视频 | 一区在线播放 | 91在线 | 亚洲| 国产精品自线在线播放 | 免费看片免费播放 | 69香蕉视频 | 久久香蕉国产线看观看乱码 | 免费看黄色大片 | 性生活大片免费看 | 国产成人99精品免费观看 | 欧美特级限制片高清 | 青青草精品在线视频 | 夜夜精品视频一区二区 | 国产正在播放 | 国产一区二区三区四区偷看 | 搞黄在线观看 | 青青草国产成人久久91网 | 91在线区啪国自产网页 | 亚洲国产精品婷婷久久 | 免费人成年短视频在线观看免费网站 | 给我一个可以看片的www日本 | 免费一级毛片在线视频观看 | 欧美特黄级乱色毛片 | 中文字幕在线观看第一页 | 99在线视频精品 | 亚洲一级毛片欧美一级说乱 | 亚洲制服丝袜在线播放 | 亚洲日本人成网站在线观看 | 国产2区 | 在线观看国产亚洲 | 欧美a级在线| 国产精品一区二区av | 免费jizz在在线播放国产 | 一级黄色毛片免费看 | 欧美视频在线一区二区三区 | 欧美成 人激情视频 | 日本黄色小视频在线观看 | 色一区二区 | 玖玖在线国产精品 | 日韩欧美国产一区二区三区四区 | 国产日韩在线观看视频网站 |