c#删除移动硬盘中$RECYCLE.BIN的文件、建立索引文件

2023-10-12 19:40

本文主要是介绍c#删除移动硬盘中$RECYCLE.BIN的文件、建立索引文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.IO;
using System.Threading;

namespace 为硬盘文件建立索引
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
        /// <summary>
        /// 文件路径
        /// </summary>
        string fpath = "";

        /// <summary>
        /// 初始化路径
        /// </summary>
        /// <param name="rootDirectory"></param>
        private void BeginWrite(string rootDirectory)
        {

            fpath = @rootDirectory + "index.txt";
        }

        /// <summary>
        /// 写一行数据
        /// </summary>
        /// <param name="Text"></param>
        private void WriteText(string Text)
        {
            File.AppendAllText(fpath, Text + "\r\n");
        }

        /// <summary>
        /// 创建索引按钮
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btnCreateIndex_Click(object sender, EventArgs e)
        {

            DriveInfo[] DriveInfos = DriveInfo.GetDrives();
            foreach (DriveInfo di in DriveInfos)
            {
                if (di.DriveType == DriveType.Fixed)
                {
                    string rootDirectory = di.RootDirectory.FullName;
                   
                    ///textBoxRoot.Text输入的盘符(如:H)
                    if (rootDirectory.StartsWith(textBoxRoot.Text.Trim().ToUpper()))
                    {
                        lbIndex.Visible = true;
                        btnCreateIndex.Enabled = false;
                        BeginWrite(rootDirectory);
                        Thread th = RunNew(CreateIndex, rootDirectory);
                        th.Join();//主线程等待线程th运行完毕
                        // CreateIndex(rootDirectory);
                        btnCreateIndex.Enabled = true;
                        lbIndex.Visible = false;
                        MessageBox.Show("成功!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
                    }
                }
            }
        }

        /// <summary>
        /// 创建索引函数
        /// </summary>
        /// <param name="PareDirectory"></param>
        private void CreateIndex(object PareDirectory)
        {
            string[] Files = Directory.GetFiles(PareDirectory.ToString());//文件列表
            string[] DirectoryInfos = Directory.GetDirectories(PareDirectory.ToString());//文件夹列表
            int DirectoryCount = DirectoryInfos.Length;//子文件夹个数
            for (int k = 0; k < Files.Length; k++)
            {
                try
                {
                    if (Files[k].Contains("$RECYCLE.BIN")) File.Delete(Files[k]);
                    else WriteText(Files[k]);
                }
                catch
                {
                    continue;
                }
            }
            for (int i = 0; i < DirectoryCount; i++)
            {
                try
                {
                    if ((new DirectoryInfo(DirectoryInfos[i]).Attributes & FileAttributes.Hidden) == FileAttributes.Hidden)
                    {
                        continue;
                    }
                    CreateIndex(DirectoryInfos[i]);
                }
                catch
                {
                    continue;
                }
            }

        }

        /// <summary>
        /// 创建新线程
        /// </summary>
        /// <param name="vfunc"></param>
        /// <param name="para"></param>
        /// <returns></returns>
        private Thread RunNew(myFunction vfunc, object para)
        {
            Thread th = new Thread(new ParameterizedThreadStart(vfunc));
            th.Start(para);
            return th;
        }
        private delegate void myFunction(object obj);

        /// <summary>
        /// 窗体加载
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void Form1_Load(object sender, EventArgs e)
        {
            System.Windows.Forms.Control.CheckForIllegalCrossThreadCalls = false;
            lbIndex.Visible = false;
        }
    }
}

 

 

我用这个方法把自己的移动硬盘上的$RECYCLE.BIN中的文件删除成功,然后还建议了索引文件。

如下:

 

 

 

本人邮箱:pukuimin@qq.com

 

这篇关于c#删除移动硬盘中$RECYCLE.BIN的文件、建立索引文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/198020

相关文章

C#读写文本文件的多种方式详解

《C#读写文本文件的多种方式详解》这篇文章主要为大家详细介绍了C#中各种常用的文件读写方式,包括文本文件,二进制文件、CSV文件、JSON文件等,有需要的小伙伴可以参考一下... 目录一、文本文件读写1. 使用 File 类的静态方法2. 使用 StreamReader 和 StreamWriter二、二进

C#中Guid类使用小结

《C#中Guid类使用小结》本文主要介绍了C#中Guid类用于生成和操作128位的唯一标识符,用于数据库主键及分布式系统,支持通过NewGuid、Parse等方法生成,感兴趣的可以了解一下... 目录前言一、什么是 Guid二、生成 Guid1. 使用 Guid.NewGuid() 方法2. 从字符串创建

Mysql实现范围分区表(新增、删除、重组、查看)

《Mysql实现范围分区表(新增、删除、重组、查看)》MySQL分区表的四种类型(范围、哈希、列表、键值),主要介绍了范围分区的创建、查询、添加、删除及重组织操作,具有一定的参考价值,感兴趣的可以了解... 目录一、mysql分区表分类二、范围分区(Range Partitioning1、新建分区表:2、分

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤

python删除xml中的w:ascii属性的步骤

《python删除xml中的w:ascii属性的步骤》使用xml.etree.ElementTree删除WordXML中w:ascii属性,需注册命名空间并定位rFonts元素,通过del操作删除属... 可以使用python的XML.etree.ElementTree模块通过以下步骤删除XML中的w:as

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左