如何解决在python中打开多个预定义的文本文件
| 您好,我只是想知道是否可以在python中打开多个预定义的文本文件。 我在下面有一些代码(尚不起作用),第一个函数有一个类别参数,这些类别都是在测试用例下面预定义的所有文本文件名。我需要尝试按以下定义打开所有文本文件,以将它们输入到sql数据库中。data_entry(categories):
with open ((categories)\"*.txt\"),\"r\") as categories:
lines = categories.readlines()
for line in lines:
data = line.split()
number = data[0]
value = data[1]
cursor.execute(\"\"\"INSERT INTO popularity (PersonNumber,category,value)
VALUES(%s,%s,%s)\"\"\",(number,value))
if __name__ == \'__main__\':
data_entry([\'movies\',\'sports\',\'actors\',\'tv\',\'games\',\\
\'activities\',\'musicians\',\'books\'])
这可能吗?如果是这样,我将如何使它按我的需要工作?
先感谢您!
解决方法
使用字符串插值或格式将类别放入文件规范,并使用“ 1”进行解析。
, 您为什么要将这些行读入列表,然后在事实之后进行遍历?
import glob,itertools
def data_entry(categories):
globs = [glob.iglob(category + \"*.txt\") for category in categories]
for filename in itertools.chain(*globs):
with open(filename) as f:
for line in f:
number,value = line.split()
cursor.execute(...)
itertools.chain
; glob
;清单理解
, Python不是Perl,因此即使更长一些,您也应该编写易于阅读的代码。并且new with语法仅在较新的python上可用。
您应该能够使此序列适应您的代码
import fnmatch
import os
for file in os.listdir(\'.\'):
if fnmatch.fnmatch(file,\'*.txt\'):
print(file)
要不就:
data_entry(categories):
foreach category in categories:
f = open (\"%s.txt\" % (category)),\"r\")
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。