Python中的sqlite3提取与元组中的值相对应的条目 - python

我正在寻找一个sqlite3命令,让我选择一个元组给定的条目,让我用一个示例进行说明:

这是我的数据:

my_data = [(1,8),(2,4),(3,5),(4,7),(5,13)]

我正在尝试提取第一个值为1,2或4的条目;因此,我想要的输出是:

[(1, 8), (2, 4), (4, 7)]

我可以通过下面的代码来实现;但是,我认为我的代码不是最佳的:

import sqlite3

my_data = [(1,8),(2,4),(3,5),(4,7),(5,13)]

key_indexes = (1,2,4)

conn = sqlite3.connect(':memory:')

c = conn.cursor()

c.execute('''CREATE TABLE my_table
          (val_1 INTEGER, val_2 INTEGER)''')

for entry in my_data:
    c.execute('''INSERT INTO my_table VALUES(?,?)''',entry)

conn.commit()

result = []

for ind in key_indexes:
    c.execute('''SELECT* FROM my_table WHERE val_1 = ?''', (ind,))
    temp_res = c.fetchall()

    result.extend(temp_res)

我正在寻找可以用sqlite3命令替换for循环的代码。
我想在此行中的某处粘贴(1,2,4)

c.execute('''SELECT* FROM my_table WHERE val_1 = ?''', (ind,))

而不是执行for循环。
先感谢您

参考方案

要替换最后一个for循环,您可以在字符串中建立索引/索引列表,然后只访问数据库一次。
请注意,这是一个分为两个步骤的过程,并且不容易受到SQL injection攻击。

my_query = '''SELECT val_1, val_2
              FROM   my_table 
              WHERE  val_1 IN ({:s});'''.format(",".join("?"*len(key_indexes)))
# -> 'SELECT val_1, val_2 FROM my_table WHERE val_1 IN (?,?,?);'
c.execute(myquery, ind).fetchall()

另外:
您没有直接询问这个问题,但是可以将第一个for循环和对execute()的调用简化为对executemany()的单个调用。
您应该测试这两个选项中哪个更快,因为DB-API并未确切指定executemany()的实现方式;而是,各RDBMS的性能可能有所不同。

c.executemany('''INSERT INTO my_table VALUES (?,?);''', my_data)

您可以在此处阅读executemany():http://www.python.org/dev/peps/pep-0249/
现在,只需说它以第二个参数为参数序列即可。

R'relaimpo'软件包的Python端口 - python

我需要计算Lindeman-Merenda-Gold(LMG)分数,以进行回归分析。我发现R语言的relaimpo包下有该文件。不幸的是,我对R没有任何经验。我检查了互联网,但找不到。这个程序包有python端口吗?如果不存在,是否可以通过python使用该包? python参考方案 最近,我遇到了pingouin库。

如何用'-'解析字符串到节点js本地脚本? - python

我正在使用本地节点js脚本来处理字符串。我陷入了将'-'字符串解析为本地节点js脚本的问题。render.js:#! /usr/bin/env -S node -r esm let argv = require('yargs') .usage('$0 [string]') .argv; console.log(argv…

Python:传递记录器是个好主意吗? - python

我的Web服务器的API日志如下:started started succeeded failed 那是同时收到的两个请求。很难说哪一个成功或失败。为了彼此分离请求,我为每个请求创建了一个随机数,并将其用作记录器的名称logger = logging.getLogger(random_number) 日志变成[111] started [222] start…

Python-Excel导出 - python

我有以下代码:import pandas as pd import requests from bs4 import BeautifulSoup res = requests.get("https://www.bankier.pl/gielda/notowania/akcje") soup = BeautifulSoup(res.cont…

Matplotlib'粗体'字体 - python

跟随this example:import numpy as np import matplotlib.pyplot as plt fig = plt.figure() for i, label in enumerate(('A', 'B', 'C', 'D')): ax = f…