如果我有清单,例如
[{'id': '129', 'label': 'UK 9 (Out of Stock)', 'price': '0', 'oldPrice': '0', 'products': ['105514', False, '0'], 'disabled': 'disabled'},
{'id': '130', 'label': 'UK 9½', 'price': '0', 'oldPrice': '0', 'products': ['105515', True, '0'], 'disabled': ''},
{'id': '131', 'label': 'UK 10 (Out of Stock)', 'price': '0', 'oldPrice': '0', 'products': ['105516', False, '0'], 'disabled': 'disabled'}]
list = []
result = []
for x in list:
if x["disabled"] == '':
result.append(x)
print(result)
在不禁用或为true等的情况下获取列表的元素。
我想知道如果我的名单很长,最快的方法是什么。
所有的答案表示赞赏,谢谢。
参考方案
这是与时间估算值的比较。我使用了list comprehension
和pandas DataFrame
。将数据加载为数据框后,数据框方法会更快。但是,如果您还考虑加载数据,则显然是列表理解才是赢家。
我列出了1000,000个词典,每个词典的结构都与您相似。
注意:
该测试是在带有两个CPU的Google笔记本电脑上进行的。操作系统:Ubuntu Linux。
我还修改了代码,以帮助使用val.get('id')
而不是所需的val.get('disabled')
检查输出。
制作虚拟数据
import numpy as np
import pandas as pd
def make_dict(id=0, disabled=True):
dis = 'disabled' if disabled else ''
d = {'id': id, 'label': 'UK 9½', 'price': '0', 'oldPrice': '0', 'products': ['105515', True, '0'], 'disabled': dis}
return d
def make_list(size=10, seed=0):
np.random.seed(seed=seed)
status = (np.random.rand(size)>0.5)
ids = np.arange(size) + 1
vals = [make_dict(id = id, disabled = disabled) for id, disabled in zip(ids, status)]
return vals
vals = make_list(size=1000000, seed=0)
df = pd.DataFrame(vals)
1.测试列表理解(最佳选项:最快)
%%time
ids = [val.get('id') for val in vals if val.get('disabled')=='']
输出:
CPU times: user 178 ms, sys: 0 ns, total: 178 ms
Wall time: 184 ms
2.测试Pandas DataFrame(不加载数据)
在这里,我们不考虑将数据加载为数据帧所需的时间。
%%time
ids = df.loc[df['disabled']=='','id'].tolist()
输出:
CPU times: user 68.4 ms, sys: 6.03 ms, total: 74.4 ms
Wall time: 75.6 ms
3.测试Pandas DataFrame(带有数据加载)
在这里,我们包含将数据加载为数据帧所需的时间。
%%time
df = pd.DataFrame(vals)
ids = df.loc[df['disabled']=='','id'].tolist()
输出:
CPU times: user 1.2 s, sys: 49.5 ms, total: 1.25 s
Wall time: 1.26 s
R'relaimpo'软件包的Python端口 - python我需要计算Lindeman-Merenda-Gold(LMG)分数,以进行回归分析。我发现R语言的relaimpo包下有该文件。不幸的是,我对R没有任何经验。我检查了互联网,但找不到。这个程序包有python端口吗?如果不存在,是否可以通过python使用该包? python参考方案 最近,我遇到了pingouin库。
如何用'-'解析字符串到节点js本地脚本? - python我正在使用本地节点js脚本来处理字符串。我陷入了将'-'字符串解析为本地节点js脚本的问题。render.js:#! /usr/bin/env -S node -r esm let argv = require('yargs') .usage('$0 [string]') .argv; console.log(argv…
Python:传递记录器是个好主意吗? - python我的Web服务器的API日志如下:started started succeeded failed 那是同时收到的两个请求。很难说哪一个成功或失败。为了彼此分离请求,我为每个请求创建了一个随机数,并将其用作记录器的名称logger = logging.getLogger(random_number) 日志变成[111] started [222] start…
Python-Excel导出 - python我有以下代码:import pandas as pd import requests from bs4 import BeautifulSoup res = requests.get("https://www.bankier.pl/gielda/notowania/akcje") soup = BeautifulSoup(res.cont…
Matplotlib'粗体'字体 - python跟随this example:import numpy as np import matplotlib.pyplot as plt fig = plt.figure() for i, label in enumerate(('A', 'B', 'C', 'D')): ax = f…