Qt 递归与非递归遍历文件【深度遍历/广度遍历/迭代器】
作者:互联网
在实现文件传输这一功能的过程中,经常需要遍历文件夹,下面对QT中文件夹的遍历方法做一个整理。
遍历可以分为递归与非递归两大类。
递归
递归主要可以归纳为四个步骤:①通过QDir访问目标文件夹②过滤所需的文件类型③获取过滤后的文件信息列表④遍历文件信息列表,取出文件路径并递归调用遍历函数。
实现方法一(深度遍历,代码非常简洁)
void fileTraverse(QString path)
{
QDir dir(path);
if(!dir.exists())
return;
dir.setFilter(QDir::Dirs | QDir::Files | QDir::NoDotAndDotDot | QDir::Hidden); //过滤后只留下文件夹、文件以及隐藏文件,不包括当前文件夹和上级文件夹
dir.setSorting(QDir::DirsFirst); //优先排列文件夹
foreach(QFileInfo info,dir.entryInfoList())
{
if(info.isFile())
{
//do what you wanna do
}
else
{
//do what you wanna do
fileTraverse(info.filePath());
}
}
}
实现方法二(深度遍历)
void fileTraverse(QString path)
{
QDir dir(path);
if(!dir.exists())
{
return;
}
dir.setFilter(QDir::Dirs | QDir::Files | QDir::NoDotAndDotDot | QDir::Hidden);
dir.setSorting(QDir::DirsFirst); //优先排列文件夹
QFileInfoList list = dir.entryInfoList();
for(int i=0; i<list.size(); i++)
{
QFileInfo fileInfo = list.at(i);
if(fileInfo.isFile())
{
//do what you wanna do
}
else
{
//do what you wanna do
fileTraverse(fileInfo.filePath());
}
}
}
非递归
递归遍历代码简洁,但效率比较低。以下是两种非递归的方法,方法三利用队列进行广度遍历,方法四使用的是迭代器。
实现方法三(广度遍历,队列)
void bfsFileTraverse(QString path)
{
QFileInfo currentInfo(path);
QDir dir(path);
if(!dir.exists())
return;
QQueue<QFileInfo> infoQueue; //队列
infoQueue.enqueue(currentInfo);
while(!infoQueue.isEmpty())
{
dir = infoQueue.head().filePath(); //取出队列第一个元素作为当前元素
infoQueue.dequeue();
dir.setFilter(QDir::Dirs | QDir::Files | QDir::NoDotAndDotDot | QDir::Hidden); //过滤后只留下文件夹、文件以及隐藏文件,不包括当前文件夹和上级文件夹
dir.setSorting(QDir::DirsFirst); //优先排列文件夹
QFileInfoList list = dir.entryInfoList();
for(int i=0; i<list.size(); i++)
{
if(list.at(i).isFile())
{
//do what you wanna do
}
else
{
//do what you wanna do
infoQueue.enqueue(list.at(i).filePath());
}
}
}
}
实现方法四(迭代器)
void fileTraverse(QString path)
{
QStringList fileList;
QDir dir(path);
if(!dir.exists())
{
return;
}
QDirIterator dirIterator(path,QDir::Dirs | QDir::Files | QDir::NoDotAndDotDot | QDir::Hidden,QDirIterator::Subdirectories);
while(dirIterator.hasNext())
{
dirIterator.next();
QFileInfo fileInfo = dirIterator.fileInfo();
if(fileInfo.isFile())
{
qDebug()<<fileInfo.fileName(); //输出文件名
}
QString fileName = fileInfo.absoluteFilePath();
fileList.append(fileName);
}
}
【参考文章】
标签:遍历,Qt,递归,QDir,文件夹,path,dir 来源: https://blog.csdn.net/weixin_41001497/article/details/109827096