2013-01-15 18 views

Odpowiedz

13

Można użyć coś jak ten

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

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

Albo użyć FileInfo.Extension nieco bezpieczniejsze niż String.Split ale może być wolniejszy

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(); 

Albo jak juharr wymienić można również użyć System.IO.Path.GetExtension

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

też użyć 'Path.GetExtension' – juharr

+1

Tak, istnieje wiele sposobów, tylko to, co działa najlepiej dla OP, To trochę wstyd "Directory.GetFiles" nie pozwala na wielokrotne rozszerzenia –

1

Masz różne alternatywy.

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

Lub:

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

Albo (jeśli nie używać rozszerzeń Linq):

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); 
}