在python 2中,我使用map将函数应用于多个项目,例如,删除所有与模式匹配的项目:
map(os.remove,glob.glob("*.pyc"))
当然我忽略了os.remove的返回码,我只想删除所有文件。它创建了一个列表的临时实例,但没有成功。
使用Python 3时,由于map返回一个迭代器而不是一个列表,因此上面的代码不执行任何操作。
我找到了一种解决方法,因为os.remove返回None,所以我使用any强制对整个列表进行迭代,而无需创建list(性能更好)
any(map(os.remove,glob.glob("*.pyc")))
但这似乎有些危险,特别是将其应用于返回内容的方法时。另一种用单行代码而不创建不必要列表的方法?
参考方案
从map()(以及从2.7到3.x的许多其他函数)的更改返回一个生成器而不是一个列表是一种节省内存的技术。在大多数情况下,更正式地写出循环不会影响性能(出于可读性的考虑,它甚至是首选)。
我将提供一个示例,但@vaultah在注释中将其钉牢:仍然是单线的:
for x in glob.glob("*.pyc"): os.remove(x)
Python sqlite3数据库已锁定 - python
我在Windows上使用Python 3和sqlite3。我正在开发一个使用数据库存储联系人的小型应用程序。我注意到,如果应用程序被强制关闭(通过错误或通过任务管理器结束),则会收到sqlite3错误(sqlite3.OperationalError:数据库已锁定)。我想这是因为在应用程序关闭之前,我没有正确关闭数据库连接。我已经试过了: connectio…Python-crontab模块 - python
我正在尝试在Linux OS(CentOS 7)上使用Python-crontab模块我的配置文件如下:{ "ossConfigurationData": { "work1": [ { "cronInterval": "0 0 0 1 1 ?", "attribute&…python-docx应该在空单元格已满时返回空单元格 - python
我试图遍历文档中的所有表并从中提取文本。作为中间步骤,我只是尝试将文本打印到控制台。我在类似的帖子中已经看过scanny提供的其他代码,但是由于某种原因,它并没有提供我正在解析的文档的预期输出可以在https://www.ontario.ca/laws/regulation/140300中找到该文档from docx import Document from…Python:集群作业管理 - python
我在具有两个阶段的计算群集(Slurm)上运行python脚本,它们是顺序的。我编写了两个python脚本,一个用于阶段1,另一个用于阶段2。每天早上,我检查所有第1阶段的工作是否都以视觉方式完成。只有这样,我才开始第二阶段。通过在单个python脚本中组合所有阶段和作业管理,是否有一种更优雅/自动化的方法?我如何知道工作是否完成?工作流程类似于以下内容:w…Python Pandas导出数据 - python
我正在使用python pandas处理一些数据。我已使用以下代码将数据导出到excel文件。writer = pd.ExcelWriter('Data.xlsx'); wrong_data.to_excel(writer,"Names which are wrong", index = False); writer.…