Path.Combine:
什么時候會用到Path.Combine呢?,當然是連接路徑字符串的時候!
所以下面的代碼可以完美的工作:
public static void Main()
{
string[] arr_pa = { @"c:/abc/", @"c:/abc" };
string[] arr_pb = { @"test.txt" };
foreach (string pa in arr_pa)
{
foreach (string pb in arr_pb)
{
Console.WriteLine("'{0}' + '{1}'= '{2}'", pa, pb, Path.Combine(pa, pb));
}
}
}
結果如下:
當然你也可以:
Console.WriteLine("'{0}' + '{1}'= '{2}'", pa, pb, Path.Combine(pa, "def", pb));
結果是:
從這個例子可以知道,我們不需要考慮arr_pa里面的字符串是不是以”/” 結尾,這的確提供了方便,而且這也是很多人喜歡使用Path.Combine的一個原因,但是僅此而已。
Path.Combine 雖然解決了路徑連接問題,但是由于很多人片面的去理解它,所有它非常容易造成錯誤的應用,要想用好Path.Combine 并非易事,下面我會列舉幾個實例來說明這點。
第一個:當path2 是相對路徑的時候,返回的是path2,path1會被丟棄。
看一下下面的代碼:
public static void Main()
{
string[] arr_pa = { @"c:/abc/", @"c:/abc" };
string[] arr_pb = { @"/test.txt", @"/test.txt", @"test.txt" };
foreach (string pa in arr_pa)
{
foreach (string pb in arr_pb)
{
Console.WriteLine("'{0}' + '{1}'= '{2}'", pa, pb, Path.Combine(pa, pb));
}
}
}
你知道這段代碼輸出什么嗎?
這段代碼的輸出如下:
可以看到對于”/test.txt” 和”/test.txt” ,Path.Combine 認為path2是相對路徑,所以直接返回path2.。
第二點:路徑是驅動器,返回的結果不正確
public static void Main()
{
string[] arr_pa = { @"c:", @"c:/" };
string[] arr_pb = { @"/test.txt", @"/test.txt", @"test.txt" };
foreach (string pa in arr_pa)
{
foreach (string pb in arr_pb)
{
Console.WriteLine("'{0}' + '{1}'= '{2}'", pa, pb, Path.Combine(pa, pb));
}
}
}
輸出結果是:
可以看到,如果path1 是” C:”的話,那么Path.Combine結果就是不正確的。
第三點:無法連接http路徑
除了連接本地路路徑之外,有的時候,也需要拼接http鏈接地址,可惜的是System.IO.Path.Combine卻無法拼接http地址。
將arr_pa 修改為
string[] arr_pa = { @"http://www.Test.com/", @"http://www.Test.com" };
結果如下:
在這里就沒有什么技巧了,純粹的死記硬背,
記住,只有
才會產生正確的解。
如果你將代碼修改為:
public static void Main()
{
string[] arr_pa = { @"http://www.Test.com/", @"http://www.Test.com" };
string[] arr_pb = { @"/test.txt", @"/test.txt", @"test.txt" };
foreach (string pa in arr_pa)
{
foreach (string pb in arr_pb)
{
Console.WriteLine("'{0}' + '{1}'= '{2}'", pa, pb, Path.Combine(pa, "def", pb));
}
}
}
那么無論怎樣,你都無法得到正確的結果:
正是因為上述的幾點不足,導致Path.Combine 很難用,這也是有一部分人選擇使用String.Format 的原因了。
當然,我寫了一個MyPath.Combine的方法,可以解決上面的問題。 string firstPath = paths[0]; if (firstPath.StartsWith("HTTP", StringComparison.OrdinalIgnoreCase)) if (!firstPath.EndsWith(spliter)) for (int i = 1; i < paths.Length; i++) if (i != paths.Length - 1)//not the last one builder.Append(nextPath); return builder.ToString();
class MyPath
{
public static string Combine(params string[] paths)
{
if (paths.Length == 0)
{
throw new ArgumentException("please input path");
}
else
{
StringBuilder builder = new StringBuilder();
string spliter = "http://";
{
spliter = "/";
}
{
firstPath = firstPath + spliter;
}
builder.Append(firstPath);
{
string nextPath = paths[i];
if (nextPath.StartsWith("/") || nextPath.StartsWith("http://"))
{
nextPath = nextPath.Substring(1);
}
{
if (nextPath.EndsWith("/") || nextPath.EndsWith("http://"))
{
nextPath = nextPath.Substring(0, nextPath.Length - 1) + spliter;
}
else
{
nextPath = nextPath + spliter;
}
}
}
}
}
}
使用也比較簡單
例如:
public static void Main()
{
string[] arr_pa = { @"c:/abc/", @"c:/abc", @"http://www.Test.com/", @"http://www.Test.com" };
string[] arr_pb = { @"/test.txt", @"/test.txt", @"test.txt" };
foreach (string pa in arr_pa)
{
foreach (string pb in arr_pb)
{
Console.WriteLine("'{0}' + '{1}'= '{2}'", pa, pb, MyPath.Combine(pa, pb));
}
}
}
結果如下:
當然,你也可以這樣:
Console.WriteLine("{0}+{1}+{2}+{3}={4}",
pa, "p2", "http://p3/", pb, MyPath.Combine(pa, "p2", "http://p3/", pb));
輸出如下:
最后如果你不用Path.Combine,那么還可以選擇string.Format
新聞熱點
疑難解答