日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python sqlite数据库一对多_Python:使用sqlite3进行多处理

發布時間:2025/4/5 python 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python sqlite数据库一对多_Python:使用sqlite3进行多处理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

我有一個SQLite3數據庫.我需要解析10000個文件.我從每個文件中讀取一些數據,然后使用此數據查詢數據庫以獲得結果.我的代碼在單個進程環境中工作正常.但是在嘗試使用多重處理池時出現錯誤.

My approach without multiprocessing (works OK):

1. Open DB connection object

2. for f in files:

foo(f, x1=x1, x2=x2, ..., db=DB)

3. Close DB

My approach with multiprocessing (does NOT work):

1. Open DB

2. pool = multiprocessing.Pool(processes=4)

3. pool.map(functools.partial(foo, x1=x1, x2=x2, ..., db=DB), [files])

4. pool.close()

5. Close DB

我收到以下錯誤:sqlite3.ProgrammingError:未調用Base Cursor .__ init__.

我的DB類實現如下:

def open_db(sqlite_file):

"""Open SQLite database connection.

Args:

sqlite_file -- File path

Return:

Connection

"""

log.info('Open SQLite database %s', sqlite_file)

try:

conn = sqlite3.connect(sqlite_file)

except sqlite3.Error, e:

log.error('Unable to open SQLite database %s', e.args[0])

sys.exit(1)

return conn

def close_db(conn, sqlite_file):

"""Close SQLite database connection.

Args:

conn -- Connection

"""

if conn:

log.info('Close SQLite database %s', sqlite_file)

conn.close()

class MapDB:

def __init__(self, sqlite_file):

"""Initialize.

Args:

sqlite_file -- File path

"""

# 1. Open database.

# 2. Setup to receive data as dict().

# 3. Get cursor to execute queries.

self._sqlite_file = sqlite_file

self._conn = open_db(sqlite_file)

self._conn.row_factory = sqlite3.Row

self._cursor = self._conn.cursor()

def close(self):

"""Close DB connection."""

if self._cursor:

self._cursor.close()

close_db(self._conn, self._sqlite_file)

def check(self):

...

def get_driver_net(self, net):

...

def get_cell_id(self, net):

...

函數foo()看起來像這樣:

def foo(f, x1, x2, db):

extract some data from file f

r1 = db.get_driver_net(...)

r2 = db.get_cell_id(...)

整體不起作用的實施如下:

mapdb = MapDB(sqlite_file)

log.info('Create NetInfo objects')

pool = multiprocessing.Pool(processes=4)

files = [get list of files to process]

pool.map(functools.partial(foo, x1=x1, x2=x2, db=mapdb), files)

pool.close()

mapdb.close()

為了解決這個問題,我想我需要在每個池工作者中創建MapDB()對象(因此有4個并行/獨立的連接).但我不知道該怎么做.有人能告訴我如何用Pool實現這個目標嗎?

最佳答案 那樣定義foo怎么樣:

def foo(f, x1, x2, db_path):

mapdb = MapDB(db_path)

... open mapdb

... process data ...

... close mapdb

然后將pool.map調用更改為:

pool.map(functools.partial(foo, x1=x1, x2=x2, db_path="path-to-sqlite3-db"), files)

更新

另一個選擇是自己處理工作線程并通過隊列分配工作.

from Queue import Queue

from threading import Thread

q = Queue()

def worker():

mapdb = ...open the sqlite database

while True:

item = q.get()

if item[0] == "file":

file = item[1]

... process file ...

q.task_done()

else:

q.task_done()

break

...close sqlite connection...

# Start up the workers

nworkers = 4

for i in range(nworkers):

worker = Thread(target=worker)

worker.daemon = True

worker.start()

# Place work on the Queue

for x in ...list of files...:

q.put(("file",x))

# Place termination tokens onto the Queue

for i in range(nworkers):

q.put(("end",))

# Wait for all work to be done.

q.join()

終止令牌用于確保關閉sqlite連接 – 如果重要的話.

總結

以上是生活随笔為你收集整理的python sqlite数据库一对多_Python:使用sqlite3进行多处理的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲天堂第一区 | 天天看a | 免费欧美黄色 | 日韩欧美片 | 涩涩视频在线观看免费 | 日本特黄特黄刺激大片 | 噜噜噜噜私人影院 | 天堂成人在线视频 | 欧美在线 | 国产免费黄色大片 | 欧美三级免费观看 | 亚洲一区二区在线视频 | 色综合天天操 | 精品欧美黑人一区二区三区 | 免费观看黄一级视频 | 亚洲一区二区三区免费看 | 国产xx在线观看 | www.色黄| 免费国产黄色片 | 国产精品自拍区 | 久久久久久亚洲av毛片大全 | 午夜一级影院 | 国产日韩一区二区在线观看 | 色视频一区二区 | 欧美视频a | 日韩黄色一级大片 | 痴汉电车在线播放 | www九九九| 欧美日韩一二三四 | 亚洲三级欧美 | 乱精品一区字幕二区 | 蜜桃av免费 | 在线观看国产区 | 免费在线黄色片 | 日韩欧美不卡在线 | 少女忠诚电影高清免费 | 精品交短篇合集 | 一区二区三区天堂 | 一级毛片aa| 亚洲自拍偷拍欧美 | 影音先锋啪啪 | 欧美激情视频网址 | 夜夜骚av一区二区三区 | 黑森林福利视频导航 | 国产日韩精品suv | 国产一区二区网 | 精品国产网站 | japanese在线观看 | 亚洲va在线∨a天堂va欧美va | 国产片久久 | 91av在线免费观看 | 久久久久久久久久免费 | 中文字幕在线视频播放 | 黄视频免费看在线 | 国产特黄一级片 | 中文字幕人妻精品一区 | 国产精品99久久久久久www | 久久96视频 | 成人性生交视频免费观看 | 日韩在线视频免费播放 | a天堂资源在线 | 日韩一片 | 国产高清自拍一区 | 91极品尤物 | 伊人色婷婷 | 韩国伦理片免费看 | 一级女性全黄久久生活片免费 | 男人天堂视频网 | 日韩av不卡在线播放 | 狠久久 | 九九日韩| 国产精品xx | 中文字幕欧美日韩 | 亚洲无av | 不卡的av片 | 丝袜制服影音先锋 | 在线观看日韩精品 | 阿的白色内裤hd中文 | 5a毛片| 久久911 | 亚洲精品欧洲 | 日韩精品视频在线观看网站 | 日韩乱码在线观看 | 久久永久免费 | 国产精品自慰网站 | 999久久久久久 | 狠狠综合久久av一区二区 | 欧美一区二区三区国产 | 亚洲人妻一区二区 | 黑人操日本 | 亚洲1级片| 久久久久久久久久久久国产精品 | 一级看片 | 国产精品字幕 | 国产69精品久久久久久久久久 | 白洁av | 日韩亚洲一区二区 | 一级黄色大片免费 | 国产主播99 |