是這段# 将下拉输入框中的内容按行写入表格的后续列 for i, value in enumerate(combobox_values): # 执行SQL插入语句,将数据写入表格的后续列 cursor.execute( "UPDATE {} SET 點檢狀態 = ?, 點檢日期 = ?, 點檢時間 = ?, 點檢人 = ?, 點檢綫別 = ?, 點檢班別 = ?, 機種 = ?, 點檢表名稱 = ?, IP地址 = ?, 用戶名 = ? WHERE id = ?".format( data41), (value, data1, data2, data3, data4, data5, data6, sheet_name, ip_address, username, last_row + i + 1)),不寫入ID
时间: 2024-04-14 19:29:17 浏览: 18
要将这段代码修改为不写入 `ID` 字段,您只需要在 `UPDATE` 语句中省略 `id` 字段的赋值部分即可。修改后的代码如下所示:
```python
# 将下拉输入框中的内容按行写入表格的后续列
for i, value in enumerate(combobox_values):
# 执行SQL插入语句,将数据写入表格的后续列
cursor.execute(
"UPDATE {} SET 點檢狀態 = ?, 點檢日期 = ?, 點檢時間 = ?, 點檢人 = ?, 點檢綫別 = ?, 點檢班別 = ?, 機種 = ?, 點檢表名稱 = ?, IP地址 = ?, 用戶名 = ?".format(data41),
(value, data1, data2, data3, data4, data5, data6, sheet_name, ip_address, username))
```
这样,`ID` 字段将不会被更新,而其他字段的值将根据指定的参数进行更新。
相关问题
# 创建工作簿和工作表 workbook = openpyxl.Workbook() sheet = workbook.active # 将文本框中的内容按行写入工作表 for i, line in enumerate(text.split("\n")): if line.strip() != "": sheet.cell(row=i + 1, column=1, value=line.strip()) # 将下拉输入框中的内容按行写入工作表 for i, value in enumerate(combobox_values): sheet.cell(row=i + 2, column=2, value=value) # 保存工作簿 workbook.save(filename)將這段代碼修改為每次打開都從數據的空白行開始寫入
你可以使用openpyxl库的worksheet.max_row属性来获取工作表的最后一行,然后从下一行开始写入数据。修改后的代码如下:
```
workbook = openpyxl.load_workbook(filename)
sheet = workbook.active
# 获取工作表的最后一行
last_row = sheet.max_row
# 将文本框中的内容按行写入工作表
for i, line in enumerate(text.split("\n")):
if line.strip() != "":
sheet.cell(row=last_row + i + 1, column=1, value=line.strip())
# 将下拉输入框中的内容按行写入工作表
for i, value in enumerate(combobox_values):
sheet.cell(row=last_row + i + 2, column=2, value=value)
# 保存工作簿
workbook.save(filename)
```
这样,每次打开文件后,数据都会从工作表的空白行开始写入。
def save_file(self): # 获取文本框中的内容 text = self.textbox.get("1.0", tk.END) # 获取下拉输入框中的内容 combobox_values = [] for child in self.textbox.winfo_children(): if isinstance(child, tk.ttk.Combobox): combobox_values.append(child.get()) # 获取当前日期作为文件名 today = datetime.date.today().strftime("%Y%m%d") filename = f"Excel_{today}.xlsx" # 创建工作簿和工作表 workbook = openpyxl.Workbook() sheet = workbook.active # 将文本框中的内容按列写入工作表 for i, line in enumerate(text.split("\n")): if line.strip() != "": sheet.cell(row=1, column=i + 1, value=line.strip()) # 将下拉输入框中的内容按列写入工作表 for i, value in enumerate(combobox_values): sheet.cell(row=2, column=i + 1, value=value) # 保存工作簿 workbook.save(filename)將這段代碼修改寫入下拉輸入框和文本内容時按行寫入
可以将文本框中的内容和下拉输入框中的内容按行写入工作表,代码如下:
```
def save_file(self):
# 获取文本框中的内容
text = self.textbox.get("1.0", tk.END)
# 获取下拉输入框中的内容
combobox_values = []
for child in self.textbox.winfo_children():
if isinstance(child, tk.ttk.Combobox):
combobox_values.append(child.get())
# 获取当前日期作为文件名
today = datetime.date.today().strftime("%Y%m%d")
filename = f"Excel_{today}.xlsx"
# 创建工作簿和工作表
workbook = openpyxl.Workbook()
sheet = workbook.active
# 将文本框中的内容按行写入工作表
for i, line in enumerate(text.split("\n")):
if line.strip() != "":
sheet.cell(row=i + 1, column=1, value=line.strip())
# 将下拉输入框中的内容按行写入工作表
for i, value in enumerate(combobox_values):
sheet.cell(row=i + 1, column=2, value=value)
# 保存工作簿
workbook.save(filename)
```
这样,文本框中的每一行都会按行写入工作表的第一列,下拉输入框中的每一行都会按行写入工作表的第二列。