これを行う方法を見つけました。それには問題がありますが、すべてを含めると、非常にスムーズに機能します。
XMLを生成するには:
DataContractSerializer ser = new DataContractSerializer(typeof(Project));
StringBuilder objectSB = new StringBuilder();
XmlWriter objectWriter = XmlWriter.Create(objectSB);
//I'm using this method in the object I want to serialize (hence the 'this')
ser.WriteObject(objectWriter, this);
objectWriter.Flush();
次に、StringBuilderをLinqtoXMLのXElementに変換できます。
Xelement xProject = Xelement.Parse(objectSB.ToString());
デシリアライズの場合:
DataContractSerializer ser = new DataContractSerializer(typeof(Project));
Project project = (CoilProject)ser.ReadObject(xProject.CreateReader());
逆シリアル化および再シリアル化せずに、LinqtoXMLを使用してXMLを編集することが数回あります。DataContractSerializerが追加する名前空間のため、これが必要になります。
//place this somewhere in your project's namespace
public static class MyExtensions
{
public static IEnumerable<XElement> ElementsAnyNS(this XElement source, string localName)
{
return source.Elements().Where(e => e.Name.LocalName == localName);
}
public static XElement ElementAnyNS(this XElement source, string localName)
{
return source.Elements().Where(e => e.Name.LocalName == localName).Select(e => e).Single();
}
}
これらの拡張メソッドを使用すると、名前空間を気にすることなく、シリアル化されたオブジェクトから1つまたは複数の要素を選択できます。これらの拡張メソッドを、LINQの名前空間を無視するというPavelMinaevの回答からXMLに適合させました。