• C# I/O 文件和目录一 : Path


    目录

    一.相对路径和绝对路径

    二.特点

    三.方法:


    一.相对路径和绝对路径

    了解Path之前 首先需要了解一下 绝对路径相对路径

    相对路径:当前程序运行所在的路径。
    绝对路径:文件在计算机的完整路径。

    例如:
    C:\Users\source\repos\LudwigIO\LudwigIO\bin\Debug\LudwigIO.exe  这个就是绝对路径
    绝对路径完全指定位置:无论当前位置如何,都可以唯一标识文件或目录。
     而 .\bin\Debug\LudwigIO.exe 就是相对路径
    相对路径指定部分位置:定位使用相对路径指定的文件时,当前位置用作起点。

    二.特点

    1.Path是一个静态类
    2.类的 Path 字段以及类的某些成员 Path 的确切行为依赖于平台
    3.类的 Path 大多数成员不会与文件系统交互并且不验证路径字符串指定的文件是否存在
    4. Path 修改路径字符串的类成员(例如 ChangeExtension)对文件系统中的文件名称没有影响。

    三.方法:

    public string path = "G://111//1.png";
    此 path供以下示例使用

    ChangeExtension(String, String)     
    更改路径字符串的扩展名。

    1. public void ChangeExtension() {
    2. string _path = Path.ChangeExtension(path, "jpg");
    3. Console.WriteLine($"新的拓展名:{_path}");
    4. }

    注:这个方法并不会真的改变我的文件后缀名,只是得到了一个新的路径

    Combine(String, String)     
    将两个字符串组合成一个路径。
    Combine(String, String, String)     
    将三个字符串组合成一个路径。
    Combine(String, String, String, String)     
    将四个字符串组合成一个路径。
    Combine(String[])     
    将字符串数组组合成一个路径。

    1. public void Combine() {
    2. string _path = Path.Combine(path, "jpg");
    3. Console.WriteLine($"路径连接:{_path}");
    4. }

    注:路径链接只是得到一个拼接路径并不代表真的有这个路径

    GetDirectoryName(ReadOnlySpan)     
    返回由字符范围表示的指定路径的目录信息。
    GetDirectoryName(String)     
    返回指定路径的目录信息。 

    1. public void GetDirectoryName() {
    2. string _path = Path.GetDirectoryName(path);
    3. Console.WriteLine($"获取文件路径:{_path}");
    4. }

    GetExtension(ReadOnlySpan)     
    返回由只读字符范围表示的文件路径的扩展名。
    GetExtension(String)     
    返回指定路径字符串的扩展名(包括句点“.”)。

    1. public void GetExtension() {
    2. string _path = Path.GetExtension(path);
    3. Console.WriteLine($"获取文件后缀名:{_path}");
    4. }

     

    GetFileName(ReadOnlySpan)     
    返回由只读字符范围表示的文件路径的文件名和扩展名。
    GetFileName(String)     
    返回指定路径字符串的文件名和扩展名。

    1. public void GetFileName() {
    2. string _path = Path.GetFileName(path);
    3. Console.WriteLine($"获取文件名+拓展名:{_path}");
    4. }

    GetFileNameWithoutExtension(ReadOnlySpan)     
    返回文件名,该文件名不带由只读字符范围表示的文件路径扩展名。
    GetFileNameWithoutExtension(String)     
    返回不具有扩展名的指定路径字符串的文件名。

    1. public void GetFileNameWithoutExtension() {
    2. string _path = Path.GetFileNameWithoutExtension(path);
    3. Console.WriteLine($"获取文件名 不加 拓展名:{_path}");
    4. }

    GetFullPath(String)     
    返回指定路径字符串的绝对路径。
    GetFullPath(String, String)     
    从完全限定的基路径和相对路径返回绝对路径。

    1. public void GetFullName() {
    2. string fileName = "myfile.ext";
    3. string path1 = @"mydir";
    4. string path2 = @"\mydir";
    5. string _path = Path.GetFullPath(fileName);
    6. Console.WriteLine($"获取全部路径1:{_path}");
    7. _path = Path.GetFullPath(path1);
    8. Console.WriteLine($"获取全部路径2:{_path}");
    9. _path = Path.GetFullPath(path2);
    10. Console.WriteLine($"获取全部路径3:{_path}");
    11. }

     注:不用 \ 修饰的路径会取到当前程序运行路径+传入路径的拼接(绝对路径) 

    带有 \ 的路径返回的是当前输入(相对路径)

    同样 输出的路径 不代表当前真的存在这个路径 

    GetInvalidFileNameChars()     
    获取包含不允许在文件名中使用的字符的数组。

    1. public void GetInvalidFileNameChars() {
    2. char[] invalidFileNameChars = Path.GetInvalidFileNameChars();
    3. string _all = string.Join("", invalidFileNameChars);
    4. Console.WriteLine($"不允许在文件名中使用的字符的数组 :{_all}");
    5. }

    有些乱码 没有深究 有兴趣的可以研究一下

    GetInvalidPathChars()     
    获取包含不允许在路径名中使用的字符的数组。

    1. public void GetInvalidPathChars() {
    2. char[] invalidPathChars = Path.GetInvalidPathChars();
    3. string _all = string.Join("", invalidPathChars);
    4. Console.WriteLine($"不允许在路径中使用的字符的数组 :{_all}");
    5. }

     

    有些乱码 没有深究 有兴趣的可以研究一下

    GetPathRoot(ReadOnlySpan)     
    从指定字符范围包含的路径中获取根目录信息。
    GetPathRoot(String)     
    从指定字符串包含的路径中获取根目录信息。

    1. public void GetPathRoot() {
    2. string _pathRoot = Path.GetPathRoot(path);
    3. Console.WriteLine($"获取根目录:{_pathRoot}");
    4. string _pathRoot1 = Path.GetPathRoot(@".\1.png");
    5. Console.WriteLine($"获取根目录:{_pathRoot1}");
    6. string _pathRoot2 = Path.GetPathRoot(@"\1.png");
    7. Console.WriteLine($"获取根目录:{_pathRoot2}");
    8. string _pathRoot3 = Path.GetPathRoot(Path.GetFullPath(@"\1.png"));
    9. Console.WriteLine($"获取根目录:{_pathRoot3}");
    10. }

     

    注:相对路经无法取到根目录 绝对路径可以 

    GetRandomFileName()     
    返回随机文件夹名或文件名。

    1. public void GetRandomFileName() {
    2. string randomFileName = Path.GetRandomFileName();
    3. Console.WriteLine($"获取随机文件名:{randomFileName}");
    4. }

    注:并不存在该文件 只是给你随机一个名字出来

    GetTempFileName()     
    在磁盘上创建一个唯一命名的零字节临时文件,并返回该文件的完整路径。

    1. public void GetTempFileName() {
    2. string tempFileName = Path.GetTempFileName();
    3. Console.WriteLine($"获取临时文件路径:{tempFileName}");
    4. }

     

    注:真实存在的文件

    GetTempPath()     
    返回当前用户的临时文件夹的路径。

    1. public void GetTempPath() {
    2. string tempPath = Path.GetTempPath();
    3. Console.WriteLine($"获取临时文件夹路径{tempPath}");
    4. }

     

    HasExtension(ReadOnlySpan)     
    确定指定字符范围表示的路径是否包含文件扩展名。
    HasExtension(String)     
    确定路径是否包括文件扩展名。

    1. public void HasExtension() {
    2. string tempPath = @".\1.png";
    3. bool has = Path.HasExtension(tempPath);
    4. Console.WriteLine($"是否包含后缀名:{has}");
    5. string tempPath2 = @".\1\";
    6. bool has1 = Path.HasExtension(tempPath2);
    7. Console.WriteLine($"是否包含后缀名:{has1}");
    8. }

     

    IsPathRooted(ReadOnlySpan)     
    返回一个值,该值指示表示文件路径的指定字符范围是否包含根。
    IsPathRooted(String)     
    返回一个值,该值指示指定的路径字符串是否包含根。

    1. public void IsPathRooted() {
    2. string tempPath = @".\1.png";
    3. bool has = Path.IsPathRooted(tempPath);
    4. Console.WriteLine($"是否包含根:{has}");
    5. string tempPath2 = @"G:\111\1.png";
    6. bool has1 = Path.IsPathRooted(tempPath2);
    7. Console.WriteLine($"是否包含根:{has1}");
    8. }

     

  • 相关阅读:
    关于面试,95%会问到的Java面试题(高级部分)
    领导都在用的Python有多厉害
    HBuilder左侧工具栏不见了
    Jdk8 动态编译 Java 源码为 Class 文件(三)
    【案例分享】配置设备作为PPPoE Client,实现接入Internet
    图扑软件用数据可视化形式告诉你,楼宇建设如何数字化转型
    Python之哈希表-遍历和有序性
    Java算法之动态规划详解-买卖股票最佳时机
    单片机硬件和软件延时是啥意思?
    Unity中Shader的GI的直接光实现
  • 原文地址:https://blog.csdn.net/SmillCool/article/details/127414515