iOS开发按时间排序文件

默认的,我们在开发中,写入沙盒里的文件按文件名排序,如0,1,2,3,4,5,a,b,c,.....z等,但有时候咱们需要将里面的文件按创建时间来排序。这时候,怎么做呢?

NSFileManager中的attributesOfItemAtPath:方法可以获取沙盒内的文件信息,其中就有NSFileCreationDate和NSFileModificationDate两个属性分别代表文件创建时间和修改时间,我们可以比较两个文件的这两个属性,实现按创建时间排序或者按修改时间排序。

NSFileManager *fileMgr = [NSFileManager defaultManager]; NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES); NSString *rootPath = [paths objectAtIndex:0];/*获取根目录*/ NSArray *pathsArr = [fileMgr subpathsAtPath:rootPath];/*取得文件列表*/ NSArray *sortedPaths = [pathsArr sortedArrayUsingComparator:^(NSString * firstPath, NSString* secondPath) { NSString *firstUrl = [rootPath stringByAppendingPathComponent:firstPath];/*获取前一个文件完整路径*/ NSString *secondUrl = [rootPath stringByAppendingPathComponent:secondPath];/*获取后一个文件完整路径*/ NSDictionary *firstFileInfo = [[NSFileManager defaultManager] attributesOfItemAtPath:firstUrl error:nil];/*获取前一个文件信息*/ NSDictionary *secondFileInfo = [[NSFileManager defaultManager] attributesOfItemAtPath:secondUrl error:nil];/*获取后一个文件信息*/ id firstData = [firstFileInfo objectForKey:NSFileCreationDate];/*获取前一个文件创建时间*/ id secondData = [secondFileInfo objectForKey:NSFileCreationDate];/*获取后一个文件创建时间*/ return [firstData compare:secondData];//升序 // return [secondData compare:firstData];//降序 }]; //    这样最后得到的sortedPaths就是我们按创建时间排序后的文件,然后我们就可以根据自己的需求来操作已经排序过的文件了,如删除最先创建的文件等: NSEnumerator *e = [sortedPaths objectEnumerator]; NSString *filename; while ((filename = [e nextObject])) { NSRange range = [filename rangeOfString:@"文件后缀.txt"]; if (range.location != NSNotFound) { [[NSFileManager defaultManager] removeItemAtPath:[rootPath stringByAppendingPathComponent:filename] error:NULL];//由于文件夹是升序排列,每次删除都是删最先创建的文件 }

//注意这里写你要停下删除文件的判断出来,比如计算沙盒文件夹里的大小,大小删到一定程度不再删除,不然会把文件全部删除 /* doSomeThing*/ }

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java 源码分析

SparkStreaming 入门

2468
来自专栏大数据和云计算技术

SparkStreaming入门

黄文辉同学第二篇,请大家支持! 1.SparkStreaming简介 Spark Streaming属于核心Spark API的扩展,支持实时数据流的可扩展、高...

3634
来自专栏技术专栏

MapReduce学习笔记

wordcount: 统计文件中每个单词出现的次数需求:1) 文件内容小:shell2)文件内容很大:TB GB ??? 如何解决大数据量的统计分析==> ur...

1322
来自专栏行者悟空

Spark RDD的Action

1556
来自专栏大数据-Hadoop、Spark

Spark Streaming + Kafka整合

2755
来自专栏Jed的技术阶梯

Kafka 0.8.2.2 Producer报错:java.net.ConnectException: Connection timed out: no further information

1.1K2
来自专栏Hadoop实操

Spark2Streaming读Kerberos环境的Kafka并写数据到Kudu

1.1K3
来自专栏Hadoop实操

Spark2Streaming读Kerberos环境的Kafka并写数据到Hive

在前面的文章Fayson介绍了一些关于Spark2Streaming的示例如《Spark2Streaming读Kerberos环境的Kafka并写数据到HBas...

1.1K3
来自专栏美图数据技术团队

RDD原理与基本操作 | Spark,从入门到精通

欢迎阅读美图数据技术团队的「Spark,从入门到精通」系列文章,本系列文章将由浅入深为大家介绍 Spark,从框架入门到底层架构的实现,相信总有一种姿势适合你,...

2.6K2
来自专栏Albert陈凯

4.3 RDD操作

4.3 RDD操作 RDD提供了一个抽象的分布式数据架构,我们不必担心底层数据的分布式特性,而应用逻辑可以表达为一系列转换处理。 通常应用逻辑是以一系列转换(...

2807

扫码关注云+社区

领取腾讯云代金券