フラットな XML データを階層フォルダーにグループ化しようとしています。
以下に示すコードは機能します。私は次のものを見つけようとしています:
Console.WriteLine("\t\t{0}
の構文を、 内部の foreach ステートメントの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();
}
}
}