我正在尝试将平面 XML 数据分组到分层文件夹中。
下面显示的代码有效。我试图找到以下内容:
- 如何将 synatx for 更改为内部foreach 语句中的
Console.WriteLine("\t\t{0}
内容 。f.Element("FILE_NAME").Value);
f.FileName
- 我还能做些什么来提高效率和/或可读性吗?
我目前使用的是 4.0,但不介意了解使这款啤酒更佳的新版本的新功能
谢谢
代码:
using System;
using System.Linq;
using System.Xml.Linq;
namespace TestingStuff
{
class LinqQuestion
{
static void Main(string[] args)
{
Question();
#region End Console
Console.WriteLine();
Console.WriteLine();
Console.WriteLine("*".PadRight(30, '*'));
Console.WriteLine("Done");
#if DEBUG
{
Console.WriteLine("Press any key to exit.");
Console.WriteLine("Where is the any key? --Homer Simpson");
Console.ReadKey(true);
}
#endif
#endregion
}
private static void Question()
{
int count = 0;
XDocument xmlDoc = XDocument.Parse(
@"<ROWSET>
<ROW>
<PARENT_DIR>Parent_100</PARENT_DIR>
<DIR>Folder_110</DIR>
<FILE_NAME>File_111</FILE_NAME>
</ROW>
<ROW>
<PARENT_DIR>Parent_100</PARENT_DIR>
<DIR>Folder_110</DIR>
<FILE_NAME>File_112</FILE_NAME>
</ROW>
<ROW>
<PARENT_DIR>Parent_200</PARENT_DIR>
<DIR>Folder_210</DIR>
<FILE_NAME>File_211</FILE_NAME>
</ROW>
<ROW>
<PARENT_DIR>Parent_200</PARENT_DIR>
<DIR>Folder_220</DIR>
<FILE_NAME>File_221</FILE_NAME>
</ROW>
</ROWSET>");
var rows = from d in xmlDoc.Descendants("ROW")
group d by new
{
ParentDir = d.Element("PARENT_DIR").Value,
Dir = d.Element("DIR").Value
}
;
foreach (var myRow in rows)
{
/*
* Create Folders
* Folder: PARENT_DIR\DIR\FILE_NAME
*
*/
try
{
string[] folders = new string[] { myRow.Key.ParentDir, myRow.Key.Dir };
string newFolder = String.Join("\\", folders);
count++;
Console.WriteLine("{0}\t{1}", count, newFolder);
foreach (var f in myRow)
{
Console.WriteLine("\t\t{0}", f.Element("FILE_NAME").Value);
}
}
catch (Exception ex)
{
Console.WriteLine("Error in Copy Process:");
// Specify the XML details for failed file / row
Console.WriteLine(ex.Message);
}
}
Console.WriteLine();
Console.WriteLine("Total Count: {0}", count);
Console.WriteLine();
Console.WriteLine();
}
}
}