如何使用C#将xmlns重命名为TYPE

时间:2019-05-15 08:24:29

标签: c# xml

我正在尝试使用c#创建XML文件格式。我几乎完成了。但是,输出尚未达到我的预期。

我当前的输出是

   <?xml version="1.0"?> 
<ArrayOfMESSAGE xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">   
        <MESSAGE>
        <HEADER xmlns="M_DAT">
        </HEADER>
        <DATA_SET>

        </DATA_SET>   
        </MESSAGE> 
   </ArrayOfMESSAGE>
<MSG />

program.cs

using (FileStream fs = new FileStream("D:\\read.xml", FileMode.Create))
            {
                using (XmlWriter writer = XmlWriter.Create(fs, new XmlWriterSettings() { OmitXmlDeclaration = true, Indent = true }))
                {lstQTM);
                    writer.WriteStartElement("MSG");
                    new XmlSerializer(typeof(List<QTMList>)).Serialize(fs, lstQTMlist);
                    writer.WriteEndElement();
                }
            }

QTMList.cs

[XmlType("MESSAGE")]
    //[XmlElement("MSG")]
    public class QTMList
    {
        [XmlElement(Namespace = "M_DAT" ,ElementName ="HEADER")]
        public List<QTMMain> QTMMain { get; set; }
        [XmlElement(ElementName = "DATA_SET")]
        public List<QTMdataset> QTMdataset { get; set; }
    }

我的愿望输出是

<MSG>
<MESSAGE>
<HEADER Type="M_DAT"> 
</HEADER>
<DATA_SET SampleSize="5">
</DATA_SET>
</MESSAGE>
</MSG>

如何更改

  

xmlns

为类型

请给我一些提示

1 个答案:

答案 0 :(得分:0)

我将QTMMain类更改为

 public class QTMMain
    {
        [XmlAttribute("TYPE")]
        public string TYPE { get; set; }

        [XmlText]
        public string Value { get; set; }
        public string DEVICE_TYPE { get; set; }
        public string DEVICE_ID { get; set; }
        //[XmlType(TypeName = "DEVICE_TYPE")]
        public string SWITCH_ID { get; set; }
        //[XmlType(TypeName = "DATE_TIME")]
        public string DATE_TIME { get; set; }
        public List<QTMStats> QTMStats { get; set; }
        public List<QTM> QTM { get; set; }
}

我已添加

[XmlAttribute("TYPE")]
public string TYPE { get; set; }
[XmlText]
public string Value { get; set; }

进入上述课程,然后按我的预期打印。

谢谢@Chris Walsh先生给我提示。