带有可变表和字段名称的web2py插入,例如与字典 - python

有没有一种在运行时处理表名和字段名的方法?

我发现了对将dict作为参数的插入方法的引用
但是假设rd是一个包含10个条目的字典,key =字段名称,value =要插入的值,以下代码将失败

    db.OrdersFull.insert(rd)

带有错误:TypeError:insert()恰好接受1个参数(给定2个)
1)有什么线索吗?
2)使用此解决方案,必须在开发时仍然知道表名(OrdersFull),以任何方式插入到仅在运行时知道其名称的表中?
3)是否可以找到可用的web2py API调用的参考信息?

参考方案

要访问基于产生其名称的Python表达式的表,您可以执行以下操作:

tablename = 'mytable'
db[tablename]

这记录在here中。

要将字典与.insert()方法一起使用,可以使用标准的Python关键字参数解包:

db[tablename].insert(**mydict)

这不是特定于web2py或DAL,而是标准的Python语法。

还有一种特殊的方法可以用来过滤字典中不是表中字段的任何项目:

db.mytable.insert(**db.mytable._filter_fields(mydict))

如果要传递先前从表中选择的记录,则上面的命令很有用,因为它将自动从记录中过滤出id字段(您不想在插入时指定id,因为由数据库自动创建)。

关于API参考,除了book之外,还有this API documentation。

Python sqlite3数据库已锁定 - python

我在Windows上使用Python 3和sqlite3。我正在开发一个使用数据库存储联系人的小型应用程序。我注意到,如果应用程序被强制关闭(通过错误或通过任务管理器结束),则会收到sqlite3错误(sqlite3.OperationalError:数据库已锁定)。我想这是因为在应用程序关闭之前,我没有正确关闭数据库连接。我已经试过了: connectio…

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-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…

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

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