Próbuję dołączyć do ścieżki systemu Windows ze ścieżką względną przy użyciu Path.Combine
.
Jednak Path.Combine(@"C:\blah",@"..\bling")
zwraca C:\blah\..\bling
zamiast C:\bling\
.
Czy ktoś wie, jak to zrobić bez pisania własnego narzędzia do rozpoznawania ścieżki względnej (co nie powinno być zbyt trudne)?
Odpowiedzi:
Co działa:
string relativePath = "..\\bling.txt"; string baseDirectory = "C:\\blah\\"; string absolutePath = Path.GetFullPath(baseDirectory + relativePath);
(wynik: absolutePath = "C: \ bling.txt")
Co nie działa
string relativePath = "..\\bling.txt"; Uri baseAbsoluteUri = new Uri("C:\\blah\\"); string absolutePath = new Uri(baseAbsoluteUri, relativePath).AbsolutePath;
(wynik: absolutePath = „C: /blah/bling.txt”)
źródło
C:\\blah..\\bling.txt
i to nie zadziała. W takim przypadku możesz ręcznie dodać je do ciągu lub zrobićPath.GetFullPath(Path.Combine(baseDirectory, relativePath))
C:\bling.txt
?Wywołaj Path.GetFullPath w połączonej ścieżce http://msdn.microsoft.com/en-us/library/system.io.path.getfullpath.aspx
> Path.GetFullPath(Path.Combine(@"C:\blah\",@"..\bling")) C:\bling
(Zgadzam się, że Path.Combine powinien zrobić to sam)
źródło
Path.GetFullPath(Path.Combine(@"..\..\blah",@"\bling"))
Path.GetFullPath(@"c:\windows\temp\..\system32")?
źródło
c:\windows\system32
W przypadku uniwersalnych aplikacji systemu Windows
Path.GetFullPath()
nie jest dostępna, możeszSystem.Uri
zamiast tego użyć klasy:Uri uri = new Uri(Path.Combine(@"C:\blah\",@"..\bling")); Console.WriteLine(uri.LocalPath);
źródło
To da ci dokładnie to, czego potrzebujesz (ścieżka NIE musi istnieć, aby to zadziałało)
DirectoryInfo di = new DirectoryInfo(@"C:\blah\..\bling"); string cleanPath = di.FullName;
źródło
Uważaj na Backslashes, nie zapomnij o nich (nie używaj dwukrotnie :)
string relativePath = "..\\bling.txt"; string baseDirectory = "C:\\blah\\"; //OR: //string relativePath = "\\..\\bling.txt"; //string baseDirectory = "C:\\blah"; //THEN string absolutePath = Path.GetFullPath(baseDirectory + relativePath);
źródło
Path.GetFullPath()
nie działa ze ścieżkami względnymi.Oto rozwiązanie, które działa zarówno ze ścieżkami względnymi, jak i bezwzględnymi. Działa na obu Linux + Windows i zachowuje
..
zgodnie z oczekiwaniami na początku tekstu (w spoczynku będą znormalizowane). Rozwiązanie nadal polegaPath.GetFullPath
naprawieniu z niewielkim obejściem.Jest to metoda rozszerzająca, więc używaj jej jak
text.Canonicalize()
/// <summary> /// Fixes "../.." etc /// </summary> public static string Canonicalize(this string path) { if (path.IsAbsolutePath()) return Path.GetFullPath(path); var fakeRoot = Environment.CurrentDirectory; // Gives us a cross platform full path var combined = Path.Combine(fakeRoot, path); combined = Path.GetFullPath(combined); return combined.RelativeTo(fakeRoot); } private static bool IsAbsolutePath(this string path) { if (path == null) throw new ArgumentNullException(nameof(path)); return Path.IsPathRooted(path) && !Path.GetPathRoot(path).Equals(Path.DirectorySeparatorChar.ToString(), StringComparison.Ordinal) && !Path.GetPathRoot(path).Equals(Path.AltDirectorySeparatorChar.ToString(), StringComparison.Ordinal); } private static string RelativeTo(this string filespec, string folder) { var pathUri = new Uri(filespec); // Folders must end in a slash if (!folder.EndsWith(Path.DirectorySeparatorChar.ToString())) folder += Path.DirectorySeparatorChar; var folderUri = new Uri(folder); return Uri.UnescapeDataString(folderUri.MakeRelativeUri(pathUri).ToString() .Replace('/', Path.DirectorySeparatorChar)); }
źródło