0、说明

QDir提供了访问目录及目录下内容的类。

QDir既可以用于访问文件系统,也可以用于访问Qt 资源系统(Qt's resource system.)。

Qt用 "/" 作为目录分隔符,此外,"/" 也是URL的路径分隔符。

QDir可以指向一个用相对路径或绝对路径指明的文件。绝对路径在不同系统下不同,Linux系统下,以文件分隔符"/"开始,如:"/home/user/Documents";在Windows系统下,以某个磁盘开始,如:"C:/Documents and Settings"。相对路径直接以目录名、文件名开头,指明一个相对于当前目录的路径,如:"images/landscape.png"。

我们可以用isRelative()和isAbsolute()来检查一个QDir是绝对还是相对的。调用makeAbsolute()可以将一个相对路径的QDir转换为绝对路径的QDir。

规范化路径:不含".."、"."、逻辑链接的路径(把这些简写的路径写全),绝对路径与相对路径中都可以含有这些路径。

逻辑链接:Linux系统中路径中的local代表根目录,如果根目录为usr,规范化路径中的local就会变成usr。

1)导航与目录操作

①路径

目录路径可以通过path()获取,通过setPath()设置新路径,通过absolutePath()获取到某个目录的绝对路径。

目录名通过dirName()获取,不过如果QDir表示的是当前目录,那会返回一个 ".":

QDir("Documents/Letters/Applications").dirName() // "Applications"
QDir().dirName() // "."

目录路径也可以通过cd()、cdUp()进行修改,就像在命令行窗口中执行的那些shell命令。调用cd()时,如果传入了某个存在的目录路径,那么这个QDir就实际代表了这个目录。而cdUp()则会改变该QDir到父目录。这样的话,cd( ".." )就相当于cdUp()。

②添加、删除、修改

目录通过mkdir()创造,通过rename()重命名,通过rmdir()移除。

③检查

通过exists()检查某个目录是否存在;目录的属性可以通过 isReadable(), isAbsolute(), isRelative(), 和 isRoot() 进行检查。

④重读某目录:refresh()

2)文件与目录的内容

①路径上的要素

目录路径上有一系列的要素:文件、目录、符号链接。要素的数量通过count()得到,它们的名字通过entryList()保存在一个QStringList中,如果我们需要每个要素的信息,可以通过entryInfoList()来获取一个QList<QFileInfo>。

②构造路径、移除

通过filePath()、absoluteFilePath()构造一个从QDir指定的目录到某个文件、目录的绝对路径与相对路径。不过它们都不会检查该路径是否存在,它们仅仅用于构造路径:

QDir directory("Documents/Letters");
QString path = directory.filePath("contents.txt");
QString absolutePath = directory.absoluteFilePath("contents.txt");

通过remove()移除文件,通过rmdir()移除目录。

③filter

在用entryList()与entryInfoList()获取要素时,可以引入过滤器来筛选符合要求的要素:例如筛选包含某子串的文件、分离文件与目录等:

名字filter通过QStringList传入setNameFilters()进行构建;

属性filter通过多个用OR连接的Filter进行构建,方法是setFilter();

排序顺序由setSorting()传入的一系列用OR(即 | )连接的SortFlags构建。

可以通过match()来检查某个文件名是否符合filter。

3)当前目录与其他路径

有两类static方法用于获取路径,一类返回QDir,一类返回QString:

QDir QString Return Value
current() currentPath() The application's working directory
home() homePath() The user's home directory
root() rootPath() The root directory
temp() tempPath() The system's temporary directory

可以用setCurrent()来设置程序的工作目录。如果我们想知道应用的可执行文件所在的目录,可以用QCoreApplication::applicationDirPath()。

drives()方法给出了该文件系统的所有根目录构成的List。在Unix系统中,返回一个包含单个"/"的List,它就是系统根目录。在Windows系统下,它会返回包含系统所有盘的QList<QFileInfo>。

4)路径操作与字符串

Path中如果包含元素 ".",说明是当前目录;包含"..",说明是parent目录;包含逻辑链接说明是规范目录,规范目录通过canonicalPath()构建。

通过cleanPath()可以简化path,移除path中多余的"/"与".."。

有时我们需要构造一些自制分隔符的路径,可以用toNativeSeparators()。

5)例子

①检查目录是否存在:exists()

QDir dir("example");
if (!dir.exists())
qWarning("Cannot find the example directory");

也可以用QFile::exists()

②遍历目录、读取文件

QDir dir = QDir::root();                 // "/"
if (!dir.cd("tmp")) { // "/tmp"
qWarning("Cannot find the \"/tmp\" directory");
} else {
QFile file(dir.filePath("ex1.txt")); // "/tmp/ex1.txt"
if (!file.open(QIODevice::ReadWrite))
qWarning("Cannot create the file %s", file.name());
}

列出当前目录下的所有文件,按文件size从小到大排列:

#include <QDir>
#include <iostream> int main(int argc, char *argv[])
{
QCoreApplication app(argc, argv);
QDir dir;
dir.setFilter(QDir::Files | QDir::Hidden | QDir::NoSymLinks);
dir.setSorting(QDir::Size | QDir::Reversed); QFileInfoList list = dir.entryInfoList();
std::cout << " Bytes Filename" << std::endl;
for (int i = 0; i < list.size(); ++i) {
QFileInfo fileInfo = list.at(i);
std::cout << qPrintable(QString("%1 %2").arg(fileInfo.size(), 10)
.arg(fileInfo.fileName()));
std::cout << std::endl;
}
return 0;
}

1、模块和加载项

Header: #include <QDir>
qmake: QT += core

2、构造

QDir(QString path, QString nameFilter, QDir::SortFlags sort = SortFlags(Name | IgnoreCase), QDir::Filters filters = AllEntries) 用path构造QDir,nameFilter指定过滤的元素
QDir(QString path = QString()) 构造QDir指向path,如果path为空,则程序工作目录"."会被使用
QDir(QDir dir) 另一个QDir的副本

3、静态字段

enum Filter { Dirs, AllDirs, Files, Drives, NoSymLinks, …, CaseSensitive } 用于entryList() 和entryInfoList()中,描述了筛选选项。
flags Filters
enum SortFlag { Name, Time, Size, Type, Unsorted, …, LocaleAware } 用于entryList() 和entryInfoList()中的排序,按照 名字、大小、时间 等等排序
flags SortFlags

5、静态方法

返回值类型

方法

说明

void addSearchPath(QString prefix, QString path) 为path加前缀prefix
QString cleanPath(QString path) 移除path中冗余的分隔符,"."和".."
QDir current() 当前目录对应的QDir
QString currentPath() 当前目录的绝对路径
QFileInfoList drives() 系统根目录的list
QString fromNativeSeparators(QString pathName) 用指定分隔符进行路径分割,默认用"/"
QDir home() home目录
QString homePath() home目录的路径
bool isAbsolutePath(QString path) 是否为绝对路径
bool isRelativePath(QString path) 是否为相对路径
QChar listSeparator()

path分隔符:

Unix下是":"

Windows下是";"

bool

match(QString filter, QString fileName)

match(QStringList filters, QString fileName)

检查fileName是否符合filter的规则
QDir root() 根目录QDir
QString rootPath() 根目录路径
QStringList searchPaths(QString prefix) prefix的检索目录
QChar separator() 目录分隔符:Unix中是"/";Windows中是"\"
bool setCurrent(QString path) 设置当前工作目录
void setSearchPaths(QString prefix, QStringList searchPaths) 给搜索路径searchPaths加前缀prefix
QDir temp() 返回系统的临时目录QDir
QString tempPath() 临时目录路径
QString toNativeSeparators(QString pathName) 将pathName中的"/"分隔符转换系统分隔符,返回转换后的路径

6、实例方法

返回值类型

方法

说明

QDir &

bool

bool

QString

operator=(QDir dir)

operator!=(QDir dir)

operator==(QDir dir)

operator[](int pos)

赋值

两个QDir的路径是否相同,并不是QDir是否相等。

dir[i]:提取路径中第i个元素。等同于entryList().at(i)

QString absoluteFilePath(QString fileName) 返回指定文件的绝对路径,并不检查文件是否存在。冗余分隔符并不会被去除(通过cleanPath()去除)
absolutePath() 返回QDir的绝对路径。
canonicalPath() 返回规范化路径。
 bool cd(QString dirName)

改变QDir到dirName指定的目录。

与命令行窗口中的cd指令类似。

bool cdUp() 改变QDir到上一级目录
 uint count() 计算路径上的元素数(目录数+文件数)
 QString dirName() 目录名

QFileInfoList

QStringList

entryInfoList(QStringList nameFilters, QDir::Filters filters = NoFilter, QDir::SortFlags sort = NoSort)

entryInfoList(QDir::Filters filters = NoFilter, QDir::SortFlags sort = NoSort)

entryList(QStringList nameFilters, QDir::Filters filters = NoFilter, QDir::SortFlags sort = NoSort)

entryList(QDir::Filters filters = NoFilter, QDir::SortFlags sort = NoSort)

路径上的元素(目录+文件)及其信息 
 bool

exists(QString name)

exists()

指定路径是否存在

当前QDir对应的路径是否存在

QString  filePath(QString fileName) 返回当前目录下的fileName的路径,不管是否存在,不检查冗余分隔符。
QDir::Filters  filter() setFilter()设置的Filter值
bool

isAbsolute()

是否为绝对路径
isEmpty(QDir::Filters filters = Filters(AllEntries | NoDotAndDotDot)) 目录是否为空目录
isReadable() 是否可读
isRelative() 是否为相对路径 
isRoot() 是否为根目录
bool    makeAbsolute() 将QDir的路径转为绝对路径
mkdir(QString dirName) 新建目录
mkpath(QString dirPath) 新建路径上的所有目录
 QStringList nameFilters() 返回setNameFilters()设置的QStringList
 QString path()

返回路径,可能包含逻辑链接,但不包含冗余.和..和分隔符。

可以是绝对路径和相对路径

 void refresh() 文档刷新
 QString relativeFilePath(QString fileName) 返回fileName相较于QDir之间的路径
bool remove(QString fileName) 移除文件
removeRecursively() 移除QDir指定的目录,包括它的内容
rename(QString oldName, QString newName) 重命名
rmdir(QString dirName)

移除目录,该目录必须为空

要删除目录和目录下的内容用removeRecursively()

rmpath(QString dirPath) 移除路径dirPath,并且会一级一级删除它的父目录(在父目录只包含一个目录的时候)
void setFilter(QDir::Filters filters) 设置用于entryList() 和 entryInfoList()提取元素的Filter
setNameFilters(QStringList nameFilters) 设置用于entryList() 和 entryInfoList()提取元素的Filter List
setPath(QString path)

设置QDir路径为path,该路径是clean的,可以是绝对和相对路径。

不检查路径是否存在。

setSorting(QDir::SortFlags sort) 设置用于entryList() 和 entryInfoList()提取元素的排序算法
QDir::SortFlags  sorting() 返回setSorting()的值
 void swap(QDir &other) 互换两个QDir的值

Qt:QDir的更多相关文章

  1. QT学习笔记8:QDir类及其用法总结

    简介 QDir类提供了访问系统目录结构及其内容的与平台无关的方式. 头文件:#include <qdir.h> QDir类用来操作路径名及底层文件系统,获取关于目录路径及文件的相关信息,也 ...

  2. Qt:路径问题小结

    在做Qt项目的时候,我们难免遇到到文件路径问题. 如QFile file("text.txt")加载不成功.QPixmap("../text.png") 加载图 ...

  3. Qt:禁止qDebug的输出

    Qt:禁止qDebug的输出 在工程的.pro文件里加上以下编译批令即可: DEFINES += QT_NO_DEBUG_OUTPUT

  4. Qt:使用自定义的字体

    Qt:使用自定义的字体 1. 下载字体文件 2. 加载字体文件 3. 使用字体   QFontDatabase::addApplicationFont("XENOTRON.TTF" ...

  5. Qt:QJsonObject

    0.说明 QJsonObject在逻辑上就是一个Map或Dict!记住这一点对理解它的方法.说明很有帮助. QJsonObject类封装了JSON Object. JSON Object是一个Key- ...

  6. Qt:QJsonValue

    0.说明 QJsonValue类用于操作JSON中的各种数据. JSON是用于存储结构化数据的格式,JSON中的数据可以是六种类型: 基本类型 存储类型 bool QJsonValue::Bool d ...

  7. Qt:QJsonArray

    0.说明 QJsonArray中存储了一系列的QJsonValue.可以向其中插入.删除QJsonValue. 一个QJsonArray可以与QVariantList互相转换.可以通过size()访问 ...

  8. Qt:QUrl构造时的qrc前缀

    参考(按对我帮助从大到小排列): Qt内的各种路径(让人迷惑) - 鬼谷子com - 博客园 qt webengineview 加载本地资源方式 - beautifulday - 博客园 (17条消息 ...

  9. QT:用QWebSocket实现webchannel,实现C++与HTML通信

    基本原理是通过channel将C++对象暴露给HTML,在HTML中调用qwebchannel.js.前提是建立transport,QT只提供了一个抽象基类QWebChannelAbstractTra ...

随机推荐

  1. 20个 CSS 快速提升技巧

    作者:web秀 http://www.javanx.cn/20190321/css-skill/ 本文涵盖了20个css技巧,可以解决许多工作中常见的问题. 1.使用CSS重置(reset) css重 ...

  2. 【Vulnhub靶场】EMPIRE: BREAKOUT

    环境准备 下载靶机,导入到vmware里面,这应该不用教了吧 开机可以看到,他已经给出了靶机的IP地址,就不用我们自己去探测了 攻击机IP地址为:192.168.2.15 靶机IP地址为:192.16 ...

  3. stram流char[]保存,支持中文,Filestram需要先转byte[]才能使用,但是性能更好《转载》

    学习流的使用时(stream类),逐步遇到新的理解,记录一下 1.FileStream流是处理byte[],默认UTF8类型 当你使用wirte方法时将非byte类型的输入内容,先将内容通过转换为字节 ...

  4. 业务4P分析实践

    原创不易,求分享.求一键三连 前言 假期继续思考BI未来的方向,其实常规的BI规划也不是不能出,比如公司BI看板建设.数据指标体系建设.业务线UE模型数据监控等,但这种不会超出预期的东西自然也能算技术 ...

  5. 「SNOI2017」一个简单的询问

    「SNOI2017」一个简单的询问 简单的解法 显然可以差分一下. \[get(l,r,x)\times get(l1,r1,x)=get(1,r,x) \times get(1,r1,x)-get( ...

  6. Atcoder ARC-068

    A 不难发现从 \(5\) 开始一直往 \(6\) 转再转回来是最优的,直接模拟即可. B 不难发现可以将多余部分直接贪心消去,最后必然会剩下两个或 \(1\) 个多余的数. 如果剩下两个,此时多余的 ...

  7. 支付宝同步请求检查appid,以及公钥,私钥是否正确

    第一步:下载支付宝Demo 下载地址:https://opendocs.alipay.com/open/270/106291#%E8%BF%90%E8%A1%8C%E8%AF%B4%E6%98%8E ...

  8. HttpClient的NoHttpResponse问题

       调用第三方接口时会报NoHttpResponse异常,原因是上次的连接已经断掉了,但是客户端并未知道,复用上次连接就报错了,所以要解决这个问题,就是要校验上次链接是否断掉了  1. httpCl ...

  9. IPV4地址学习笔记

    IP地址由网络号和主机号组成.IPV4由32位正整数来表示. A类IP:8位网络号+24主机号,网络号以0开头,网络号范围0~127 B类IP:16位网络号+16主机号,网络号以10开头,网络号范围1 ...

  10. iOS 获取通讯录中联系人的所有属性 by - zfqj

    1 ABAddressBookRef addressBook = ABAddressBookCreate(); 2 3 CFArrayRef results = ABAddressBookCopyAr ...