2013-01-15 11 views

Antwort

13

Man könnte so etwas wie dieses

string[] extensions = { "jpg", "txt", "asp", "css", "cs", "xml" }; 

string[] dizin = Directory.GetFiles(@"c:\s\sent", "*.*") 
    .Where(f => extensions.Contains(f.Split('.').Last().ToLower())).ToArray(); 

verwenden oder FileInfo.Extension etwas sicherer als String.Split verwenden, aber möglicherweise langsamer

string[] extensions = { ".jpg", ".txt", ".asp", ".css", ".cs", ".xml" }; 

string[] dizin = Directory.GetFiles(@"c:\s\sent", "*.*") 
    .Where(f => extensions.Contains(new FileInfo(f).Extension.ToLower())).ToArray(); 

Oder wie juharr Sie erwähnt auch System.IO.Path.GetExtension können

string[] extensions = { ".jpg", ".txt", ".asp", ".css", ".cs", ".xml" }; 

string[] dizin = Directory.GetFiles(@"c:\s\sent", "*.*") 
    .Where(f => extensions.Contains(System.IO.Path.GetExtension(f).ToLower())).ToArray(); 
+0

Oder verwenden Sie 'Path.GetExtension' – juharr

+1

yep, es gibt viele Möglichkeiten, ist, Was auch immer am besten für OP funktioniert, es ist ein wenig schade, dass Directory.GetFiles mehrere Erweiterungen nicht erlaubt –

1

Sie haben verschiedene Alternativen.

String[] files = Directory.GetFiles(path, "*.*", SearchOption.AllDirectories).Where(s => s.ToLower().EndsWith(".jpg") || s.ToLower().EndsWith(".txt") || s.ToLower().EndsWith(".asp")); 

Oder:

String[] files = Directory.GetFiles(path).Where(file => Regex.IsMatch(file, @"^.+\.(jpg|txt|asp)$")); 

Oder (wenn Sie nicht Linq Erweiterungen verwenden):

List<String> files = new List<String>(); 
String[] extensions = new String[] { "*.jpg", "*.txt", "*.asp" }; 

foreach (String extension in extensions) 
{ 
    String[] files = Directory.GetFiles(path, found, SearchOption.AllDirectories); 

    foreach (String file in files) 
     files.Add(file); 
}