【发布时间】:2014-12-22 05:47:02
【问题描述】:
我想使用 PyMongo 的 bulk 执行写操作的写操作特性 以减少网络往返次数并增加 rite 吞吐量。
我还发现here可以用5000作为批号。
但是,我不想要批号的最佳大小以及如何在下面的代码中将 PyMongo 的批量写入操作功能与生成器结合起来?
from pymongo import MongoClient
from itertools import groupby
import csv
def iter_something(rows):
key_names = ['type', 'name', 'sub_name', 'pos', 's_type', 'x_type']
chr_key_names = ['letter', 'no']
for keys, group in groupby(rows, lambda row: row[:6]):
result = dict(zip(key_names, keys))
result['chr'] = [dict(zip(chr_key_names, row[6:])) for row in group]
yield result
def main():
converters = [str, str, str, int, int, int, str, int]
with open("/home/mic/tmp/test.txt") as c:
reader = csv.reader(c, skipinitialspace=True)
converted = ([conv(col) for conv, col in zip(converters, row)] for row in reader)
for object_ in iter_something(converted):
print(object_)
if __name__ == '__main__':
db = MongoClient().test
sDB = db.snps
main()
test.txt 文件:
Test, A, B01, 828288, 1, 7, C, 5
Test, A, B01, 828288, 1, 7, T, 6
Test, A, B01, 171878, 3, 7, C, 5
Test, A, B01, 171878, 3, 7, T, 6
Test, A, B01, 871963, 3, 9, A, 5
Test, A, B01, 871963, 3, 9, G, 6
Test, A, B01, 1932523, 1, 10, T, 4
Test, A, B01, 1932523, 1, 10, A, 5
Test, A, B01, 1932523, 1, 10, X, 6
Test, A, B01, 667214, 1, 14, T, 4
Test, A, B01, 667214, 1, 14, G, 5
Test, A, B01, 67214, 1, 14, G, 6
【问题讨论】:
标签: python mongodb python-2.7 pymongo bulkinsert