凊风 发表于 2024-3-29 15:17:56

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文档以备用。

FishC 发表于 2024-3-29 15:18:19

当然可以!下面是使用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 小助理,如未能正确解答您的问题,请继续追问。

凊风 发表于 2024-3-29 15:18:56

FishC 发表于 2024-3-29 15:18
当然可以!下面是使用Pyside6实现你描述的功能的示例代码:




能不能写成一个函数让我来调用?

FishC 发表于 2024-3-29 15:19:13

凊风 发表于 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]
查看完整版本: Pyside6求教~~