当我使用下面的代码行时,我会得到一个包含每个文件整个路径的字符串数组。
private string[] pdfFiles = Directory.GetFiles("C:\\Documents", "*.pdf");
我想知道是否有一种方法只获取字符串中的文件名,而不是整个路径。
Path.GetFileName
方法,从完整路径中获取文件名。private string[] pdfFiles = Directory.GetFiles("C:\\Documents", "*.pdf")
.Select(Path.GetFileName)
.ToArray();
编辑:上面的解决方案使用了LINQ,所以至少需要.NET 3.5。以下是适用于早期版本的解决方案:
private string[] pdfFiles = GetFileNames("C:\\Documents", "*.pdf");
private static string[] GetFileNames(string path, string filter)
{
string[] files = Directory.GetFiles(path, filter);
for(int i = 0; i < files.Length; i++)
files[i] = Path.GetFileName(files[i]);
return files;
}
Path.GetFileName(yourFileName);
(MSDN)来获取文件名。该方法只返回文件名,使其更易于理解。请注意保留HTML标记。//GetFiles on DirectoryInfo returns a FileInfo object.
var pdfFiles = new DirectoryInfo("C:\\Documents").GetFiles("*.pdf");
//FileInfo has a Name property that only contains the filename part.
var firstPdfFilename = pdfFiles[0].Name;
string[] fileEntries = Directory.GetFiles(directoryPath);
foreach (var file_name in fileEntries){
string fileName = file_name.Substring(directoryPath.Length + 1);
Console.WriteLine(fileName);
}
Substring
而不是使用Path
函数来以更稳健的方式完成相同的操作吗? - Wyck有很多种方法 :)
第一种方法:
string[] folders = Directory.GetDirectories(path, "*", SearchOption.TopDirectoryOnly);
string jsonString = JsonConvert.SerializeObject(folders);
string[] folders = new DirectoryInfo(yourPath).GetDirectories().Select(d => d.Name).ToArray();
string[] folders =
new DirectoryInfo(yourPath).GetDirectories().Select(delegate(DirectoryInfo di)
{
return di.Name;
}).ToArray();
Directory.EnumerateFiles(LoanFolder).Select(file => Path.GetFileName(file));
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace GetNameOfFiles
{
public class Program
{
static void Main(string[] args)
{
string[] fileArray = Directory.GetFiles(@"YOUR PATH");
for (int i = 0; i < fileArray.Length; i++)
{
Console.WriteLine(fileArray[i]);
}
Console.ReadLine();
}
}
}
using System.Linq;
,如果还未引用System.Core
程序集,则需要添加引用。此代码需要 .NET 3.5 或更高版本,如果需要使用 .NET 2.0,我会发布一个解决方案。 - Thomas Levesque