次のXMLをList<string>
またはString[]
に変換するにはどうすればよいですか。
<Ids>
<id>1</id>
<id>2</id>
</Ids>
完全なXMLシリアライゼーション/デシリアライゼーションではなく、単に解析しただけのようです。 LINQ to XMLを使用できる場合、これは非常に簡単です。
using System;
using System.Linq;
using System.Xml.Linq;
public class Test
{
static void Main()
{
string xml = "<Ids><id>1</id><id>2</id></Ids>";
XDocument doc = XDocument.Parse(xml);
var list = doc.Root.Elements("id")
.Select(element => element.Value)
.ToList();
foreach (string value in list)
{
Console.WriteLine(value);
}
}
}
実際には、Elements
の呼び出しは引数を省略できますareだけid
要素ですが、必要な要素を指定する方法を示すと思います。
同様に、実際にList<string>
が本当に必要な場合を除いて、 ToList
を呼び出さなくても、結果がIEnumerable<string>
になります。一度繰り返します。代わりに配列を作成するには、 ToArray
を使用します。
XmlDocumentを使用する方法は次のとおりです。
// A string containing the XML data
string xml = "<Ids><id>1</id><id>2</id></Ids>";
// The list you want to fill
ArrayList list = new ArrayList();
XmlDocument doc = new XmlDocument();
// Loading from a XML string (use Load() for file)
doc.LoadXml(xml);
// Selecting node using XPath syntax
XmlNodeList idNodes = doc.SelectNodes("Ids/id");
// Filling the list
foreach (XmlNode node in idNodes)
list.Add(node.InnerText);
あらゆるタイプのコレクション。例えば :
<Ids>
<id>C:\videotest\file0.txt</id>
<id>C:\videotest\file1.txt</id>
</Ids>
class FileFormat
{
public FileFormat(string path)
{
this.path = path;
}
public string FullPath
{
get { return Path.GetFullPath(path); }
}
public string FileName
{
get { return Path.GetFileName(path); }
}
private string path;
}
List<FileFormat> Files =
selectedNode
.Descendants("Ids")
.Elements("Id")
.Select(x => new FileFormat(x.Value))
.Where(s => s.FileName!=string.Empty)
.ToList();
文字列配列をxmlに変換するコード
itemsは文字列配列です
items.Aggregate("", (current, x) => current + ("<item>" + x + "</item>"))
このサンプルは、.NET Framework 3.5で動作します。
System.Xml.Linq.XElement element = System.Xml.Linq.XElement.Parse("<Ids> <id>1</id> <id>2</id></Ids>");
System.Collections.Generic.List<string> ids = new System.Collections.Generic.List<string>();
foreach (System.Xml.Linq.XElement childElement in element.Descendants("id"))
{
ids.Add(childElement.Value);
}
このサンプルは、.NET Framework 4.0で動作します。
リストに
List<string> Ids= new List<string>();
Ids= selectedNode.Descendants("Ids").Elements("Id").Select(> x=>x.Value).Where(s =>s!= string.Empty).ToList();
文字列に[]
string[] Ids= thisNode
.Descendants("Ids") // Ids element
.Elements("Id") // Id elements
.Select(x=>x.Value) // XElement to string
.Where(s =>s!= string.Empty) // must be not empty
.ToArray(); // string to string []
Propertiesクラスを使用できます。
Properties prop = new Properties();
prop.loadFromXML(stream);
Set set = prop.keySet();
その後、各キーのセットから文字列にアクセスできます。キーはxmlの要素名です。
DataSetを使用してXMLから型付き配列を取得する方法を次に示します。 (この例ではdoubleの配列)
DataSet dataSet = new DataSet()
DoubleArray doubles = new DoubleArray(dataSet,0);
dataSet.ReadXml("my.xml");
double a = doubles[0];
public class DoubleArray
{
DataSet dataSet;
int tableIndex;
public DoubleArray(DataSet dataSet,int tableIndex)
{
this.dataSet=dataSet;
this.tableIndex=tableIndex;
}
public double this[int index]
{
get
{
object ret = dataSet.Tables[tableIndex].Rows[index];
if(ret is double?)
return (ret as double?).Value;
else
return double.Parse(ret as string);
}
set
{
object out = dataSet.Tables[tableIndex].Rows[index];
if(out is double?)
dataSet.Tables[tableIndex].Rows[index] = (double?)value;
else
dataSet.Tables[tableIndex].Rows[index] = value.ToString();
}
}
}
もちろん、倍精度浮動小数点数を解析し、常に文字列に戻すことは、一部のプログラマーにとって冒涜と見なされる可能性があります...私にとっても、そのようなリソースの無駄を考えないのは難しいことでした...別の..それを強調しないでください:)