此篇文档是老早就放到草稿箱中了,断断续续编辑了几次。结合自己经常用到的对于文件的操作,结合msdn做此文。
1、File 类 --转自msdn
常用方法:
名称 | 说明 |
---|---|
AppendAllLines(String, IEnumerable<String>) |
向一个文件中追加行,然后关闭该文件。 如果指定文件不存在, 此方法会创建一个文件,向其中写入指定的行,然后关闭该文件。 |
AppendAllLines(String, IEnumerable<String>, Encoding) |
使用指定的编码向一个文件中追加行,然后关闭该文件。 如果指 定文件不存在,此方法会创建一个文件,向其中写入指定的行,然 后关闭该文件。 |
AppendAllText(String, String) |
打开一个文件,向其中追加指定的字符串,然后关闭该文件。 如果文件不存在,此方法将创建一个文件,将指定的字符串写 入文件,然后关闭该文件。 |
Create(String) | 在指定路径中创建或覆盖文件。 |
Create(String, Int32) | 创建或覆盖指定的文件。(string path, int bufferSize) |
Exists(String) | 确定指定的文件是否存在。bool |
Open(String, FileMode) | 以读/写访问权限打开指定路径上的 FileStream。 |
ReadAllLines(String) | 打开一个文本文件,读取文件的所有行,然后关闭该文件。 |
ReadAllText(String) | 打开一个文本文件,读取文件的所有行,然后关闭该文件。 |
创建一个新文件,向其中写入指定的字符串,然后关闭文件。 如果目标文件已存在,则覆盖该文件。 |
|
WriteAllLines(String, IEnumerable<String>) | 创建一个新文件,向其中写入一个字符串集合,然后关闭该文件。 |
使用File类用于典型操作,如复制、移动、重命名、创建、打开、删除和一次将追加到单个文件。您(这个字保留,敬亲爱的读者)还可以使用File类用于获取和设置文件属性或DateTime与创建过程中,相关信息访问及文件的写入。如果您想要在多个文件上执行操作,请参阅Directory.GetFiles 或 DirectoryInfo.GetFiles。
2、FileInfo 类 --转自msdn
提供用于创建、复制、删除、移动和打开文件的属性和实例方法,并且帮助创建 FileStream 对象。 此类不能被继承。
名称 | 说明 |
---|---|
FileInfo(String) |
初始化作为文件路径的包装的 FileInfo 类的新实例。 |
属性
名称 | 说明 | 语法 |
---|---|---|
CreationTime |
获取或设置当前文件或目录的创建时间。 (继承自 FileSystemInfo。) |
|
Directory |
获取父目录的实例。 |
public DirectoryInfo Directory { get; } |
DirectoryName |
获取表示目录的完整路径的字符串。 |
public string DirectoryName { get; } |
Exists |
获取指示文件是否存在的值。 (覆盖 FileSystemInfo.Exists。) |
public override bool Exists { get; } |
Extension |
获取表示文件扩展名部分的字符串。 (继承自 FileSystemInfo。) |
public string Extension { get; } |
FullName |
获取目录或文件的完整目录。 (继承自 FileSystemInfo。) |
public virtual string FullName { get; } |
Name |
获取文件名。 (覆盖 FileSystemInfo.Name。) |
常用方法:
名称 | 说明 |
---|---|
AppendText() |
创建一个 StreamWriter,它向 FileInfo 的此实例表示的文件追加文本。 |
CopyTo(String) |
将现有文件复制到新文件,不允许覆盖现有文件。 |
Create() | 创建文件。 |
OpenText() | 创建使用从现有文本文件中读取的 UTF8 编码的 StreamReader。 |
3、Directory 类--转自msdn
公开用于通过目录和子目录进行创建、移动和枚举的静态方法。 无法继承此类。
常用方法
名称 | 说明 | 备注 |
---|---|---|
CreateDirectory(String) |
在指定路径中创建所有目录和子目录,除非它们已经存在。 |
中指定的所有目录 path 创建的除非它们已经存在,或除非的某些部分 path 无效。 如果该目录已存在,此方法不会创建一个新目录,但它将返回 DirectoryInfo 现有目录的对象。 path 参数指定目录路径,而不是文件路径 |
CreateDirectory(String, DirectorySecurity) |
在指定路径中创建所有目录(除非已存在),并应用指定的 Windows 安全性。 |
|
Delete(String) |
从指定路径删除空目录。 |
|
Delete(String, Boolean) |
删除指定的目录,并删除该目录中的所有子目录和文件(如果表示)。 |
|
Exists(String) | 确定给定路径是否引用磁盘上的现有目录。 |
如果 path 指向现有目录,则为 true; 如果该目录不存在或者在尝试确定指定目 录是否存在时出错,则为 false。 |
GetCurrentDirectory() | 获取应用程序的当前工作目录。 | 包含当前工作目录的路径且不以反斜杠 (\) 结尾的字符串。 |
名称 | 说明 | 语法 |
---|---|---|
Exists |
获取指示目录是否存在的值。(覆盖 FileSystemInfo.Exists。) |
public override bool Exists { get; } |
Extension | 获取表示文件扩展名部分的字符串。(继承自 FileSystemInfo。) | |
FullName | 获取目录的完整路径。(覆盖 FileSystemInfo.FullName。) | |
Name | 获取此 DirectoryInfo 实例的名称。(覆盖 FileSystemInfo.Name。) | |
Parent | 获取指定的子目录的父目录。 | |
Root | 获取目录的根部分。 |
方法
名称 | 说明 | 语法 |
---|---|---|
Create() |
创建目录。 |
|
Create(DirectorySecurity) |
使用 DirectorySecurity 对象创建目录。 |
|
Delete() | 如果此 DirectoryInfo 为空则将其删除。(覆盖 FileSystemInfo.Delete()。) | |
Delete(Boolean) | 删除 DirectoryInfo 的此实例,指定是否删除子目录和文件。 | |
GetFiles() | 返回当前目录的文件列表。(FileInfo 类型的数组。) |
di.GetFiles() |
GetFiles(String) | 返回当前目录中与给定的搜索模式匹配的文件列表。(FileInfo 类型的数组。) |
di.GetFiles("*2*") di.GetFiles("test?.txt") |
综合应用的例子
class FileOperate
{
/// <summary>
/// 构造函数
/// </summary>
public FileOperate()
{
} /// <summary>
/// FileOperate1()的重载
/// 理解构造函数
/// </summary>
public void FileOperate1()
{
}
public static void Main()
{
try
{
FileOperate fo = new FileOperate();
#region 文件夹操作:是否存在,创建,删除
//string path = @"D:\MrSong1"; //正常路径
//string illeglePath = @"D:\111>"; //含有非法字符
//string overLengthPath = @"" + fo.GetLongPath(); //路径超长 //fo.DirectoryNomal(path); //正常 //fo.DirectoryNomal(illeglePath); //报“路径中存在非法字符异常”,下面的方法不执行 //fo.DirectoryNomal(overLengthPath); //修改illegalPath为正确路径后,执行此方法,报”指定路径名过长“
#endregion #region 文件操作
string filePath = @"D:\11.txt";
fo.FileOperate1(filePath);
File.Delete(filePath); //删除
#endregion }
catch (Exception ex)
{
Console.WriteLine(ex);
}
Console.ReadKey();
} /// <summary>
/// 文件夹操作
/// </summary>
/// <param name="path"></param>
private void DirectoryNomal(string path)
{
if (Directory.Exists(path))
{
Console.WriteLine("Directory类方法判断:存在路径");
Console.WriteLine("删除:" + path);
Directory.Delete(path); //删除
}
else
{
Console.WriteLine("Directory类方法判断:不存在" + path);
Console.WriteLine("创建:" + path);
Directory.CreateDirectory(path); //创建
}
DirectoryInfo dirInfo = new DirectoryInfo(path);
if (dirInfo.Exists)
{
Console.WriteLine("DirectoryInfo属性判断:存在路径" + path);
Console.WriteLine("DirectoryInfo删除:" + path);
dirInfo.Delete();
}
else
{
Console.WriteLine("DirectoryInfo属性判断:不存在路径");
Console.WriteLine("DirectoryInfo创建:" + path);
dirInfo.Create(); //创建路径
}
} /// <summary>
/// 获取长文件夹名称
/// </summary>
/// <returns></returns>
private string GetLongPath()
{
string path = "";
char[] Pattern = new char[] { '', '', '', '', '', '', '', '', '', '', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z' };
System.Random random = new Random(~unchecked((int)DateTime.Now.Ticks));
int i = ;
int n = Pattern.Length; while (i <= )
{
int rnd = random.Next(, n);
path += Pattern[rnd];
i++;
}
return path;
} /// <summary>
/// 文件操作
/// </summary>
/// <param name="path"></param>
public void FileOperate1(string path)
{
if (File.Exists(path))
{
Console.WriteLine(path + "文件存在");
File.Delete(path);
}
else
{
Console.WriteLine(path + "文件不存在");
Console.WriteLine("创建该文件!");
File.Create(path);
}
File.WriteAllLines(path, new string[] { "Hello World!" });
}
}
文件,文件夹操作
注意:
1、Exists是Directory类的方法,在DirectoryInfo中是属性。
2、DirectoryInfo类初始化(构造函数)中会报异常,有非法字符串,超长,path为null,调用方没有权限错误。