当前位置: 首页> 文旅> 文化 > 代运营服务方案_网站制作价格东莞_西安seo网站管理_简述影响关键词优化的因素

代运营服务方案_网站制作价格东莞_西安seo网站管理_简述影响关键词优化的因素

时间:2025/7/12 4:58:14来源:https://blog.csdn.net/gc_2299/article/details/143221777 浏览次数:0次
代运营服务方案_网站制作价格东莞_西安seo网站管理_简述影响关键词优化的因素

  上一篇文章实现了可视化显示不同路径下相同文件夹内的文件和子文件夹差异,文件少时已经够用,但当有成百上千个子文件夹时,人工逐个查看文件夹差异就比较困难,因此本文实现循环查找文件夹内容差异并导出为本地Excel文件的功能。
  本文使用队列保存要差异对比的文件夹及子文件夹路径,没有使用递归,代码逻辑看着稍微有点别扭,主要代码如下:

List<DirectoryCompareRecord> results= new List<DirectoryCompareRecord>();Queue<string> subDirs= new Queue<string>();string leftDir=txtLeftDir.Text.TrimEnd('\\');
string rightDir=txtRightDir.Text.TrimEnd('\\');
string curLeftDir = string.Empty;
string curRightDir = string.Empty;List<string> subLeftDirs = new List<string>();
List<string> subRightDirs = new List<string>();
List<string> subLeftFiles = new List<string>();
List<string> subRightFiles = new List<string>();string tmpFileName = string.Empty;
string tmpDirName = string.Empty;
string tmp = string.Empty;FileInfo leftFile = null;
FileInfo rightFile = null;do
{                curLeftDir = Path.Combine(leftDir, tmp);curRightDir = Path.Combine(rightDir, tmp);subLeftDirs.Clear();subRightDirs.Clear();subLeftFiles.Clear();subRightFiles.Clear();subLeftFiles.AddRange(Directory.GetFiles(curLeftDir));subRightFiles.AddRange(Directory.GetFiles(curRightDir));subLeftFiles.Sort();subRightFiles.Sort();foreach (string file in subLeftFiles){tmpFileName = Path.GetFileName(file);tmpDirName = Path.Combine(curRightDir, tmpFileName);if (!subRightFiles.Contains(tmpDirName)){DirectoryCompareRecord record = new DirectoryCompareRecord();record.ObjectType = "文件";record.ResultType = "文件缺失";record.LeftDirectory = curLeftDir;record.LeftFile = tmpFileName;results.Add(record);}else{leftFile=new FileInfo(file);rightFile=new FileInfo(tmpDirName);if (leftFile.LastWriteTime != rightFile.LastWriteTime){DirectoryCompareRecord record = new DirectoryCompareRecord();record.ObjectType = "文件";record.ResultType = "文件有差异";record.LeftDirectory = curLeftDir;record.LeftFile = tmpFileName;record.LeftFileLastModifyDate = leftFile.LastWriteTime.ToString();record.RightDirectory = curRightDir;record.RightFile = tmpFileName;record.RightFileLastModifyDate = rightFile.LastWriteTime.ToString();results.Add(record);}else{subRightFiles.Remove(tmpDirName);}                        }}foreach (string file in subRightFiles){tmpFileName = Path.GetFileName(file);tmpDirName = Path.Combine(curLeftDir, tmpFileName);if (!subLeftFiles.Contains(tmpDirName)){DirectoryCompareRecord record = new DirectoryCompareRecord();record.ObjectType = "文件";record.ResultType = "文件缺失";record.RightDirectory = curRightDir;record.RightFile = tmpFileName;results.Add(record);}}subLeftDirs.AddRange(Directory.GetDirectories(curLeftDir));subRightDirs.AddRange(Directory.GetDirectories(curRightDir));subLeftDirs.Sort();subRightDirs.Sort();foreach (string dir in subLeftDirs){tmpFileName = Path.GetFileName(dir);tmpDirName = Path.Combine(curRightDir, tmpFileName);if (!subRightDirs.Contains(tmpDirName)){DirectoryCompareRecord record = new DirectoryCompareRecord();record.ObjectType = "文件夹";record.ResultType = "文件夹缺失";record.LeftDirectory = curLeftDir;record.LeftFile = tmpFileName;results.Add(record);}else{subDirs.Enqueue(dir.Substring(leftDir.Length+1));subRightFiles.Remove(tmpDirName);                        }}foreach (string file in subRightDirs){tmpFileName = Path.GetFileName(file);tmpDirName = Path.Combine(curLeftDir, tmpFileName);if (!subLeftDirs.Contains(tmpDirName)){DirectoryCompareRecord record = new DirectoryCompareRecord();record.ObjectType = "文件夹";record.ResultType = "文件夹缺失";record.RightDirectory = curRightDir;record.RightFile = tmpFileName;results.Add(record);}}if(subDirs.Count>0){tmp=subDirs.Dequeue();}} while (subDirs.Count >0);

  对比结果导出Excel文件采用Sylvan.Data.Excel库,代码实现也比较简单,如下所示:


SaveFileDialog saveFileDialog = new SaveFileDialog();
saveFileDialog.Filter = "XLSX|*.xlsx";
if (saveFileDialog.ShowDialog() != DialogResult.OK)
{return;
}DbDataReader reader = ObjectDataReader.Create(results);
using (var w = ExcelDataWriter.Create(saveFileDialog.FileName))
{w.Write(reader);
}

  最后是程序运行效果及导出文件的效果,代码地址:https://github.com/guochao2299/DirCompare
在这里插入图片描述

在这里插入图片描述

参考文献:
[1]https://blog.csdn.net/sd7o95o/article/details/142976888
[2]https://github.com/MarkPflug/Sylvan.Data.Excel

关键字:代运营服务方案_网站制作价格东莞_西安seo网站管理_简述影响关键词优化的因素

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: