Pyside6求教~~
能不能用Pyside6实现:系统在用户指定的"self.File_Path"路径中自动生成一个123.txt文本文件;
系统自动将"self.File_Path"路径中self.Base_Workbook的sheet_name按顺序逐一写入此123.txt中(每个sheet_name又分别命名为sheet_name1:、sheet_name2:、sheet_name3:来分为3行,行与行之间以“。”来分隔)
然后打开123.txt,提示用户在sheet_name1:、sheet_name2:、sheet_name3:后录入规则(其中如sheet_name1后可能有多行规则录入,sheet_name2后可能有多行规则录入,sheet_name3后可能有多行规则录入,多行规则之间以“;”来分隔)
当录入完毕后,系统储存此123.txt文档以备用。 当然可以!下面是使用Pyside6实现你描述的功能的示例代码:
import sys
from PySide6.QtWidgets import QApplication, QMainWindow, QPushButton, QTextEdit, QVBoxLayout, QWidget
from PySide6.QtCore import QFile, QTextStream
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("自动生成文档")
self.resize(400, 300)
self.central_widget = QWidget()
self.setCentralWidget(self.central_widget)
self.layout = QVBoxLayout(self.central_widget)
self.generate_button = QPushButton("生成文档")
self.generate_button.clicked.connect(self.generate_document)
self.layout.addWidget(self.generate_button)
self.text_edit = QTextEdit()
self.layout.addWidget(self.text_edit)
def generate_document(self):
file_path = self.text_edit.toPlainText().strip()
if file_path:
with open(file_path, "w") as f:
for i, sheet_name in enumerate(self.Base_Workbook.sheet_names()):
f.write(f"sheet_name{i+1}:\n")
# 在这里你可以加入用户录入规则的代码
f.write("录入规则1;录入规则2;录入规则3\n")
f.write("。\n")
print("文档已生成!")
if __name__ == "__main__":
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec())
这段代码创建了一个简单的PySide6窗口,其中有一个文本编辑框用于输入文件路径,然后有一个按钮用于生成文档。在 `generate_document` 方法中,会按照你的描述逐一将工作簿中的表名写入到文件中,并添加用户录入的规则。你可以根据实际情况修改代码中的路径和规则录入部分。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。 FishC 发表于 2024-3-29 15:18
当然可以!下面是使用Pyside6实现你描述的功能的示例代码:
能不能写成一个函数让我来调用? 凊风 发表于 2024-03-29 15:18
能不能写成一个函数让我来调用?
当然可以!下面是一个将代码封装成函数的示例:
import sys
from PySide6.QtWidgets import QApplication, QMainWindow, QPushButton, QTextEdit, QVBoxLayout, QWidget
from PySide6.QtCore import QFile, QTextStream
def generate_document(file_path, workbook):
with open(file_path, "w") as f:
for i, sheet_name in enumerate(workbook.sheet_names()):
f.write(f"sheet_name{i+1}:\n")
# 在这里你可以加入用户录入规则的代码
f.write("录入规则1;录入规则2;录入规则3\n")
f.write("。\n")
print("文档已生成!")
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("自动生成文档")
self.resize(400, 300)
self.central_widget = QWidget()
self.setCentralWidget(self.central_widget)
self.layout = QVBoxLayout(self.central_widget)
self.generate_button = QPushButton("生成文档")
self.generate_button.clicked.connect(self.generate_document)
self.layout.addWidget(self.generate_button)
self.text_edit = QTextEdit()
self.layout.addWidget(self.text_edit)
def generate_document(self):
file_path = self.text_edit.toPlainText().strip()
if file_path:
generate_document(file_path, self.Base_Workbook)
if __name__ == "__main__":
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec())
在这个示例中,我将生成文档的代码封装到了 `generate_document` 函数中。你可以单独调用这个函数,并传入文件路径和工作簿对象作为参数。
在 `MainWindow` 类中的 `generate_document` 方法中,会根据用户输入的文件路径和工作簿对象调用 `generate_document` 函数来生成文档。
这样,你就可以在其他地方直接调用 `generate_document` 函数,而不需要依赖于窗口界面。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
页:
[1]