基于QT5的文件读取程序

一、文件读写操作QFile

QT自带了一个文件操作的类->QFile ,实验中也是着重 QFile 的操作

1.1 头文件

#include<QFile>

1.2 内部函数

在这里插入图片描述

这些函数没必要都去记住,我们只需要记住简单的例如open()readLine()atEnd()close() 等常用的函数即可

  • 首先我们new 一个 QFile 对象的时候有四种构造方法,通常来说我们传入 文件的路径名 就好了
  • 然后我们要调用open()函数,这个函数是告诉操作系统我们通过什么样的方式打开,例如只读打开、只写打开、可读可写打开……,这个和我们在C语言中的文件打开函数是类似的,我们在QIODevice看到一个枚举类型的 OpenModeFlag打开方式
enum OpenModeFlag {
        NotOpen = 0x0000,
        ReadOnly = 0x0001,
        WriteOnly = 0x0002,
        ReadWrite = ReadOnly | WriteOnly,
        Append = 0x0004,
        Truncate = 0x0008,
        Text = 0x0010,
        Unbuffered = 0x0020,
        NewOnly = 0x0040,
        ExistingOnly = 0x0080
    };

这些就是文件打开的一些模式了,可以根据自己的需求选用,我们这里既然是文件的读取显示操作,那么只需要读取,于是我们的打开方式就是:QIODevice::ReadOnly

  • 然后就是对这个文件从头到尾读取,在以前我们学的C语言中有一个文件结束标志EOF,一般这个EOF − 1 -1 1 但是这里的QFile 提供了一个函数atEnd()如果当我们读到了文件末尾,那么就会返回一个true

例如:

QFile file("in.txt");
if (!file.open(QIODevice::ReadOnly | QIODevice::Text))
    return;

while (!file.atEnd()) {
    QByteArray line = file.readLine();
    process_line(line);
}
  • 最后我们通过file.close()关闭数据流就好了

二、UI设计

这里随便画画就好了,不过可以在文本显示框插入背景图,只需要在组件的styleSheet中添加资源即可

在这里插入图片描述

在这里插入图片描述

mainwindow.ui

<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
 <class>MainWindow</class>
 <widget class="QMainWindow" name="MainWindow">
  <property name="geometry">
   <rect>
    <x>0</x>
    <y>0</y>
    <width>300</width>
    <height>500</height>
   </rect>
  </property>
  <property name="windowTitle">
   <string>MainWindow</string>
  </property>
  <property name="autoFillBackground">
   <bool>false</bool>
  </property>
  <property name="styleSheet">
   <string notr="true"/>
  </property>
  <widget class="QWidget" name="centralwidget">
   <property name="autoFillBackground">
    <bool>true</bool>
   </property>
   <property name="styleSheet">
    <string notr="true"/>
   </property>
   <layout class="QVBoxLayout" name="verticalLayout">
    <item>
     <widget class="QWidget" name="widget" native="true">
      <layout class="QHBoxLayout" name="horizontalLayout">
       <item>
        <widget class="QLabel" name="label">
         <property name="text">
          <string>文件路径</string>
         </property>
        </widget>
       </item>
       <item>
        <widget class="QPushButton" name="pushButton">
         <property name="text">
          <string>打开文件</string>
         </property>
        </widget>
       </item>
      </layout>
     </widget>
    </item>
    <item>
     <widget class="QGroupBox" name="groupBox">
      <property name="styleSheet">
       <string notr="true"/>
      </property>
      <property name="title">
       <string>文本内容:</string>
      </property>
      <layout class="QHBoxLayout" name="horizontalLayout_2">
       <item>
        <widget class="QTextEdit" name="textEdit">
         <property name="styleSheet">
          <string notr="true">background-image: url(:/a/tmp/back.png);
background-color: rgba(0, 0, 0, 12);</string>
         </property>
        </widget>
       </item>
      </layout>
     </widget>
    </item>
   </layout>
  </widget>
  <widget class="QMenuBar" name="menubar">
   <property name="geometry">
    <rect>
     <x>0</x>
     <y>0</y>
     <width>300</width>
     <height>23</height>
    </rect>
   </property>
  </widget>
  <widget class="QStatusBar" name="statusbar"/>
 </widget>
 <resources/>
 <connections/>
</ui>

三、代码

3.1 mainwindow.h

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>

QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

private:
    Ui::MainWindow *ui;
};
#endif // MAINWINDOW_H

3.2 mainwindow.c

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QFile>
#include <QFileDialog>
#include <QDebug>
#include <QPushButton>
#include <QTextStream>
#include <QFileInfo>
#include <QDateTime>

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    //使用connec函数,熟悉匿名表达式
    connect(ui->pushButton,&QPushButton::clicked,[=](){
       //点击按钮,弹出文件选择对话框
       //使用对话框,获取打开路径,注意参数一是父类对象 ,参数二是对话窗口名称 参数三是默认打开路径
       QString fileName = QFileDialog::getOpenFileName(this,
              tr("Open File"), "C:\\data");
       //使路径显示到路径 line edit地方
       ui->label->setText(fileName);
       //调试的跟踪打印
       qDebug()<<"文件路径为:"+fileName;
       //使用Qfile操作文件
       QFile file(fileName);
       //打开文件,注意参数的使用,文件修饰符,文件指针,可以和之前的嵌入式环境编程的知识联系起来,包括 模式操作
       file.open(QIODevice::ReadOnly);
       //使用数组数据结构接读取数据

       QByteArray array;
       while(!file.atEnd())
       {
           array += file.readLine(); //按行读
       }
       ui->textEdit->setText(array);
       //关闭文件数据流
       file.close();
       //编码格式类
       //QTextCodec * codec = QTextCodec::codecForName("gbk");
       QFileInfo info(fileName);
       qDebug() << "大小:" << info.size() << " 后缀名:" << info.suffix() << " 文件名称:"<<info.fileName() << " 文件路径:"<< info.filePath();
       qDebug() << "创建日期:" << info.birthTime().toString("yyyy/MM/dd hh:mm:ss");
       qDebug() << "最后修改日期:"<<info.lastModified().toString("yyyy-MM-dd hh:mm:ss");
       //获取文件名,之后,根据这个文件名找到指定文件,并打开
   });

}

MainWindow::~MainWindow()
{
    delete ui;
}

四、效果

在这里插入图片描述

我们可以看到我们的程序中将我们的日程表打开了,并且在终端打印了这个文件的一些信息,例如:路径、文件名、大小等等

  • 6
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
基于Qt实现的FTP客户端和服务端程序是一种用于文件传输的网络应用程序Qt是一个跨平台的开发框架,可以帮助开发者简化程序编写过程并实现不同操作系统下的程序兼容性。 FTP客户端通过用户操作,可以连接到FTP服务端,并进行文件的上传和下载操作。FTP客户端程序提供了用户界面,包括登录信息的输入、文件列表的展示以及上传下载按钮等。用户可以通过FTP客户端上传本地文件到FTP服务器,或者从FTP服务器下载文件到本地。上传、下载的过程中,FTP客户端会与FTP服务端进行交互,通过FTP协议进行数据传输。 FTP服务端程序则负责接收FTP客户端的连接,处理客户端的请求,并根据请求进行文件的上传和下载。FTP服务端通过监听指定的端口号,等待客户端的连接请求。一旦有客户端的连接请求,服务端接受连接,并通过鉴权确认客户端的身份。服务端程序接收客户端的上传请求后,将文件保存在服务器指定的位置;接收客户端的下载请求后,从服务器指定位置读取文件并发送给客户端。 基于Qt的FTP客户端和服务端程序可以实现跨平台的文件传输功能,提供了图形化的用户界面和方便的操作方式。科研工作者、程序员、企业等可以使用FTP客户端和服务端程序,方便地在不同设备之间进行文件传输,提高工作效率。此外,通过FTP的鉴权机制,可以保证文件传输的安全性,更好地满足用户的需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

MangataTS

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

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

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

打赏作者

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

抵扣说明:

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

余额充值