Qt 实例24 QTabelWidget交互编辑csv文件

1、C++代码

以下是一个使用QTabelWidget交互编辑CSV文件的C++代码示例:

#include <QFile>
#include <QTextStream>
#include <QTableWidget>
#include <QTableWidgetItem>

// 打开CSV文件并加载到表格中
void loadCSV(const QString& fileName, QTableWidget* table) {
    QFile file(fileName);
    if (!file.open(QIODevice::ReadOnly | QIODevice::Text)) {
        qDebug() << "Failed to open file: " << file.errorString();
        return;
    }

    QTextStream stream(&file);
    QString line;
    int row = 0;
    while ((line = stream.readLine()).count() > 0) {
        QStringList list = line.split(",");
        int col = 0;
        for (const QString& str : list) {
            QTableWidgetItem* item = new QTableWidgetItem(str);
            table->setItem(row, col, item);
            col++;
        }
        row++;
    }
}

// 将表格内容保存到CSV文件中
void saveCSV(const QString& fileName, QTableWidget* table) {
    QFile file(fileName);
    if (!file.open(QIODevice::WriteOnly | QIODevice::Text)) {
        qDebug() << "Failed to open file: " << file.errorString();
        return;
    }

    QTextStream stream(&file);
    for (int i = 0; i < table->rowCount(); i++) {
        for (int j = 0; j < table->columnCount(); j++) {
            stream << table->item(i, j)->text();
            if (j < table->columnCount() - 1) {
                stream << ",";
            }
        }
        stream << "\n";
    }
}

使用示例:

  • 创建一个QTableWidget对象,例如:

QTableWidget* table = new QTableWidget(4, 3); // 4行3列的表格
  • 加载CSV文件到表格中,例如:

QString fileName = "example.csv"; // CSV文件路径
loadCSV(fileName, table); // 加载CSV文件到表格中
  • 在表格中进行编辑,例如:

在单元格中输入内容:

table->item(0, 0)->setText("Hello"); // 将第1行第1列的单元格内容设置为"Hello"

在单元格中添加新行:

table->insertRow(0); // 在第1行插入新行

在单元格中删除行:

table->removeRow(0); // 删除第1行
  • 将表格内容保存到CSV文件中,例如:

cpQString fileName = "example_new.csv"; // 保存文件路径和名称
saveCSV(fileName, table); // 将表格内容保存到CSV文件中

2、Python 代码

以下是一个使用QTabelWidget交互编辑CSV文件的Python代码示例:

import csv
from PyQt5.QtWidgets import QMainWindow, QApplication, QTableWidget, QTableWidgetItem, QFileDialog, QAction, QMenu
from PyQt5.QtGui import QIcon
from PyQt5.QtCore import Qt

class CSVTableWidget(QMainWindow):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.setWindowTitle("CSV Table Widget")
        self.setGeometry(100, 100, 800, 600)
        self.table = QTableWidget()
        self.table.setColumnCount(2)
        self.table.setHorizontalHeaderLabels(["Name", "Value"])
        self.setCentralWidget(self.table)
        self.statusBar().showMessage("Ready")
        self.menubar = self.menuBar()
        self.file_menu = self.menubar.addMenu("File")
        self.open_action = QAction("Open", self, triggered=self.openFile)
        self.exit_action = QAction("Exit", self, triggered=self.close)
        self.file_menu.addAction(self.open_action)
        self.file_menu.addAction(self.exit_action)

    def openFile(self):
        filename, _ = QFileDialog.getOpenFileName(self, "Open file", ".", "CSV Files (*.csv)")
        if filename:
            with open(filename, "r") as csvfile:
                reader = csv.reader(csvfile)
                rows = list(reader)
            self.table.setRowCount(len(rows))
            for i in range(len(rows)):
                for j in range(len(rows[i])):
                    item = QTableWidgetItem(rows[i][j])
                    item.setFlags(item.flags() | Qt.ItemIsEditable)
                    self.table.setItem(i, j, item)
            self.table.sortItems(0, Qt.AscendingOrder)
            self.statusBar().showMessage("File opened")

    def closeEvent(self, event):
        save = QMessageBox.questionIcon()
        save = QMessageBox()
        save.setText("Do you want to save changes?")
        save.setStandardButtons(QMessageBox.Save | QMessageBox.Discard | QMessageBox.Cancel)
        result = save.exec_()
        if result == QMessageBox.Save:
            self.saveFile()
            event.accept()
        elif result == QMessageBox.Cancel:
            event.ignore()
        else:
            event.accept()

    def saveFile(self):
        filename = QFileDialog.getSaveFileName(self, "Save file", "", "CSV Files (*.csv)")
        if filename:
            with open(filename, "w", newline="") as csvfile:
                writer = csv.writer(csvfile)
                for row in range(self.table.rowCount()):
                    row_data = []
                    for column in range(self.table.columnCount()):
                        item = self.table.itemAtPosition(row, column)
                        row_data.append(item.text())
                    writer.writerow(row_data)
            self.statusBar().showMessage("File saved")

在上面的代码中,我们创建了一个名为CSVTableWidget的子类,继承自QMainWindow。在初始化函数中,我们创建了一个名为tableQTableWidget对象,并设置了列标题。然后,我们创建了一个菜单栏,并在菜单栏中添加了一个名为"File"的子菜单。在子菜单中,我们添加了两个动作,分别用于打开文件和退出程序。当用户选择打开文件时,我们使用QFileDialog对话框选择CSV文件,然后使用csv模块读取文件内容并填充到table中。当用户选择退出程序时,我们关闭窗口并触发closeEvent函数。在closeEvent函数中,我们弹出一个消息框,询问用户是否要保存更改。如果用户选择保存更改,则调用saveFile函数将表格内容保存到CSV文件中;否则,直接关闭窗口。在saveFile函数中,我们使用QFileDialog对话框选择保存文件的位置和文件名,

后续公众号会发布系列教程,更多内容请关注公众号:程序猿学习日记

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序猿学习

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值