- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的代码遇到了性能瓶颈,并决定重写它,并且需要一些有关如何解决此问题的建议。我有一个巨大的光流数据列表,其中包含带有框架、X 和 Y 坐标的列表。像这样:
[[[frame,x,y],[frame,x,y]],[[frame,x,y],[frame,x,y]]...]
我在这里上传了一个示例:http://pastebin.com/ANUr8bwc
我需要找到一种方法来管理这些数据,以便我可以快速查找并查看哪些列表包含某些帧。
到目前为止,我已经循环遍历了所有数据,以查看哪些列表包含第 34 帧和第 35 帧,然后将它们索引到新列表中以供引用。
thisFrame = 34
nextFrame = thisFrame + 1
if any(e[0] == thisFrame for e in item) and any(e[0] == nextFrame for e in item): #Check if the item contains this frame and next
DoStuff()
对 10.000 多个点的列表执行数千次,很快就会变成瓶颈。所以我的想法是为每个帧创建一个字典,这样就可以轻松找到特定帧上可用的项目:
{frame, [list1,list2,list3]}
但我想这次我最好问一下。是否有一个好的 goto 方法来存储并能够在大数据集中进行查找,以避免每次需要时都循环遍历所有数据集?
最佳答案
Dictionaries是 Python 最优化的数据结构之一。将数据转换为字典需要一些时间,但之后,查找(例如 item 中的 thisFrame
)会在 O(1)
中完成。时间,比列表快得多。
您最好的选择是使用如下代码转换为字典:
注意看起来您的列表嵌套了两次,如果不是这种情况,您将必须稍微修改迭代。
item_dict = {}
for big_lst in item:
for lst in big_lst:
try:
item_dict[lst[0]] += [lst[1:],] # Append to existing value
except KeyError:
item_dict[lst[0]] = [lst[1:],] # Initialize value
编辑 02/05:尝试/排除更快
item_dict
将如下所示,合并重复的帧,以便单帧查找将返回 [x, y] 对的列表。
item_dict = {
1: [list1, list2, list3]
2: [list1, list2]
3: [list1]
4: [list1, list2, list3]
}
从此以后的查找将会非常快:
thisFrame = 34
nextFrame = thisFrame + 1
if thisFrame in item_dict and nextFrame in item_dict:
foo = item_dict[thisFrame] # e.g. [list1, list2]
bar = item_dict[nextFrame] # e.g. [list1, list2, list3]
DoStuff()
如果您需要跟踪各个 [x, y] 对所属的父列表,您可以为每个列表添加一个附加元素,该元素将父列表的索引存储在 item
中:
item_dict = {}
for list_index, big_lst in enumerate(item):
for lst in big_lst:
if lst[0] in item_dict:
item_dict[lst[0]] += [lst[1:]+[list_index],] # Append
else:
item_dict[lst[0]] = [lst[1:]+[list_index],] # Initialize
然后,像这样的查找
parent_list = item_dict[thisFrame][2] # [x, y, list_index]
将返回可以访问的父列表:
item[parent_list]
关于python - 管理大点列表,最好的方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21521722/
我想了解 Ruby 方法 methods() 是如何工作的。 我尝试使用“ruby 方法”在 Google 上搜索,但这不是我需要的。 我也看过 ruby-doc.org,但我没有找到这种方法。
Test 方法 对指定的字符串执行一个正则表达式搜索,并返回一个 Boolean 值指示是否找到匹配的模式。 object.Test(string) 参数 object 必选项。总是一个
Replace 方法 替换在正则表达式查找中找到的文本。 object.Replace(string1, string2) 参数 object 必选项。总是一个 RegExp 对象的名称。
Raise 方法 生成运行时错误 object.Raise(number, source, description, helpfile, helpcontext) 参数 object 应为
Execute 方法 对指定的字符串执行正则表达式搜索。 object.Execute(string) 参数 object 必选项。总是一个 RegExp 对象的名称。 string
Clear 方法 清除 Err 对象的所有属性设置。 object.Clear object 应为 Err 对象的名称。 说明 在错误处理后,使用 Clear 显式地清除 Err 对象。此
CopyFile 方法 将一个或多个文件从某位置复制到另一位置。 object.CopyFile source, destination[, overwrite] 参数 object 必选
Copy 方法 将指定的文件或文件夹从某位置复制到另一位置。 object.Copy destination[, overwrite] 参数 object 必选项。应为 File 或 F
Close 方法 关闭打开的 TextStream 文件。 object.Close object 应为 TextStream 对象的名称。 说明 下面例子举例说明如何使用 Close 方
BuildPath 方法 向现有路径后添加名称。 object.BuildPath(path, name) 参数 object 必选项。应为 FileSystemObject 对象的名称
GetFolder 方法 返回与指定的路径中某文件夹相应的 Folder 对象。 object.GetFolder(folderspec) 参数 object 必选项。应为 FileSy
GetFileName 方法 返回指定路径(不是指定驱动器路径部分)的最后一个文件或文件夹。 object.GetFileName(pathspec) 参数 object 必选项。应为
GetFile 方法 返回与指定路径中某文件相应的 File 对象。 object.GetFile(filespec) 参数 object 必选项。应为 FileSystemObject
GetExtensionName 方法 返回字符串,该字符串包含路径最后一个组成部分的扩展名。 object.GetExtensionName(path) 参数 object 必选项。应
GetDriveName 方法 返回包含指定路径中驱动器名的字符串。 object.GetDriveName(path) 参数 object 必选项。应为 FileSystemObjec
GetDrive 方法 返回与指定的路径中驱动器相对应的 Drive 对象。 object.GetDrive drivespec 参数 object 必选项。应为 FileSystemO
GetBaseName 方法 返回字符串,其中包含文件的基本名 (不带扩展名), 或者提供的路径说明中的文件夹。 object.GetBaseName(path) 参数 object 必
GetAbsolutePathName 方法 从提供的指定路径中返回完整且含义明确的路径。 object.GetAbsolutePathName(pathspec) 参数 object
FolderExists 方法 如果指定的文件夹存在,则返回 True;否则返回 False。 object.FolderExists(folderspec) 参数 object 必选项
FileExists 方法 如果指定的文件存在返回 True;否则返回 False。 object.FileExists(filespec) 参数 object 必选项。应为 FileS
我是一名优秀的程序员,十分优秀!