【.NET Core】深入理解IO之File类
文章目录
- 【.NET Core】深入理解IO之File类
- 一、概述
- 二、File类
- 2.1 File.AppendAllLines方法
- 2.2 File.AppendAllText方法
- 2.3 File.Copy 方法
- 2.4 File.Create 方法
- 2.5 File.Decrypt(String) 方法
- 2.6 File.Delete(String) 方法
- 2.7 File.Move 方法
- 2.8 File.Open 方法
一、概述
C#中操作文件的最基本类就是IO类,里面就定义了很多衍生类和方法给我们对文件进行处理、转换、执行等操作;其中流分为写入流(输入流)和读取流(输出流),输出流用于对文件进行读取流操作,输入流用于对文件进行写入数据;
其中IO流中我们比较常用的类有BinaryReader(从二进制流读取原始数据), BinaryWriter(以二进制格式写入原始数据),BufferedStream(字节流的临时存储), Directory(有助于操作目录结构), DirectoryInfo(用于对目录执行操作),File(有助于处理文件),FileInfo(用于对文件执行操作), FileStream(用于文件中任何位置的读写)。
文章:【.Net Core】深入理解IO之文件和目录介绍了Directory
使用,本文将介绍File
及FileInfo
的使用。
二、File类
File
类提供了创建、复制、删除、移动和打开单一文件的静态方法,并协助创建FileStream
对象。
File
继承基类Object
,使用File
类执行典型操作,如复制、删除、移动、重命名、打开和追加到单个文件。还可以使用File
类来获取和设置文件特性或DateTime
与文件的创建、访问和写入相关的信息。如果要对多个文件进行操作,可以使用Directory.GetFiles
与DirectoryInfo.GetFiles
。
File
许多方法在创建和打开文件时返回其I/O
类型。可以使用这些进一步操作文件。
2.1 File.AppendAllLines方法
- 重载
方法 | 说明 |
---|---|
AppendAllLines(String,IEnumerable) | 向一个文件中追加行,然后关闭该文件。 如果指定文件不存在,此方法会创建一个文件,向其中写入指定的行,然后关闭该文件。 |
AppendAllLines(String,IEnumerable,Encoding) | 使用指定的编码向一个文件中追加行,然后关闭该文件。 如果指定文件不存在,此方法会创建一个文件,向其中写入指定的行,然后关闭该文件。 |
- 示例
var MarchMondays = from line in File.ReadLines(dataPath)where line.StartsWith("Monday") &&line.Contains("March")select line;
File.AppendAllLines(@"D:\temp\selectedDays.txt", MarchMondays);
2.2 File.AppendAllText方法
- 重载
方法 | 说明 |
---|---|
AppendAllText(String,String) | 打开一个文件,向其中追加指定的字符串,然后关闭该文件。 如果文件不存在,此方法将创建一个文件,将指定的字符串写入文件,然后关闭该文件。 |
AppendAllText(String,String,Encoding) | 使用指定的编码将指定的字符串追加到文件中,如果文件还不存在则创建该文件。 |
- 示例
string path = @"d:\temp\MyTest.txt";
string appendText = "This is extra text" + Environment.NewLine;
File.AppendAllText(path, appendText)
2.3 File.Copy 方法
将现有文件复制到新文件。
- 重载
方法 | 说明 |
---|---|
Copy(String,String,Boolean) | 将现有文件复制到新文件。 允许覆盖同名的文件,True覆盖 |
Copy(String,String) | 将现有文件复制到新文件。 不允许覆盖同名的文件。 |
- 示例
string sourceDir = @"e:\current";
string backupDir = @"e:\goyeer\2024";string[] txtList = Directory.GetFiles(sourceDir, "*.txt");foreach (string f in txtList){string fName = f.Substring(sourceDir.Length + 1);File.Copy(Path.Combine(sourceDir, fName), Path.Combine(backupDir, fName));}
- 注解
sourceFileName
和 destFileName
参数可以指定相对或绝对路径信息。 相对路径信息解释为相对于当前工作目录。 此方法不支持参数中的通配符。
原始文件的属性保留在复制的文件中。
2.4 File.Create 方法
创建或截断并覆盖指定路径中的文件。
- 重载
方法 | 说明 |
---|---|
Create(String) | 在指定路径中创建、截断和覆盖文件。 |
Create(String,Int32) | 在指定路径中创建、截断和覆盖文件,并指定缓冲区大小。 |
Create(String,Int32,FileOptions) | 创建或覆盖指定路径中的文件,指定缓冲区大小和一个描述如何创建或覆盖该文件的选项。 |
- 示例
string path = @"c:\goyeer\MyTest.txt";
using (FileStream fs = File.Create(path))
{byte[] info = new UTF8Encoding(true).GetBytes("This is some text in the file.");fs.Write(info, 0, info.Length);
}
- 注解
Create
中path
参数指定相对或绝对路径信息。相对路径信息解释为相对于当前工作目录。若要获取当前工作目录,使用GetCurrentDirectory
。如果指定的文件不存在,则创建该文件;如果它确实存在并且它不是只读,则删除并覆盖内容。默认情况下,向所有用户授予对新文件的完整读/写访问权限。该文件读/写访问权限打开,并且必须先关闭,然后才能由另一个应用程序打开。
2.5 File.Decrypt(String) 方法
使用Encrypt(String)方法解密由当前账号加密的文件。
- 示例
string FileName = "goyeer_config.cfg";
File.Encrypt(FileName);
Console.WriteLine("Encrypt " + FileName);
File.Decrypt(FileName);
Console.WriteLine("Decrypt " + FileName);
- 注解
方法 Decrypt
需要对正在解密的文件具有独占访问权限,如果另一个进程正在使用该文件,将引发异常。 如果文件未加密, Decrypt
将返回一个非零值,指示成功。
Encrypt
方法和 Decrypt
方法都使用安装在计算机上的加密服务提供程序 (CSP) ,以及调用方法的进程的文件加密密钥。
当前文件系统的格式必须为 NTFS,并且当前操作系统必须Windows NT或更高版本。
2.6 File.Delete(String) 方法
删除指定的文件
- 示例
string sourceDir =$"e:/temp/goyeer";
string[] txtList = Directory.GetFiles(sourceDir, "*.txt");
foreach (string path in txtList)
{File.Delete(path);
}
- 注解
指定一个文件名,其中包含参数的任何相对或绝对路径信息 path
。 不能包含通配符。 相对路径信息解释为相对于当前工作目录。如果要删除的文件不存在,则不会引发异常。
2.7 File.Move 方法
将指定文件移到新位置,提供要指定新文件名的选项。
- 重载
方法 | 说明 |
---|---|
Move(String,String) | 将指定文件移到新位置,提供要指定新文件名的选项。 |
Move(String,String,Boolean) | 将指定文件移动到新位置,提供用于指定新文件名和替换目标文件(如果已存在)的选项。 |
- 示例
string sourcePath = @"c:\temp\MyTest.txt";
string targetPath = @"c:\temp2\MyTest.txt";
File.Move(sourcePath,targetPath);
2.8 File.Open 方法
打开指定路径上的FileSteam
。
- 重载
方法 | 说明 |
---|---|
Open(String,FileMode,FileAccess,FileShare) | 打开指定路径上的 FileStream ,具有带读、写或读/写访问的指定模式和指定的共享选项。 |
Open(String,FileMode) | 通过不共享的读/写访问权限打开指定路径上的FileStream |
Open(String,FileMode,FileStreamOptions) | 使用指定的路径、创建模式、读/写和共享权限、其他 FileStreams 对同一文件的访问权限、缓冲区大小、其他文件选项和分配大小初始化 类的新实例FileStream |
Open(String,FileMode,FileAccess) | 通过指定的模式和不共享的访问权限打开指定路径上的FileStream |
- 示例
string path = @"c:\goyeer\MyTest.txt";
using (FileStream fs = File.Open(path, FileMode.Open, FileAccess.Read, FileShare.None))
{byte[] b = new byte[1024];UTF8Encoding temp = new UTF8Encoding(true);while (fs.Read(b,0,b.Length) > 0){Console.WriteLine(temp.GetString(b));}
}