使用Visual Studio 2010从xsd文件生成。net 4.0 c#类(实体)有哪些选项?


当前回答

当您使用循环引用(即类型可以直接或间接拥有自己类型的元素)时,Xsd.exe不能很好地工作。

当存在循环引用时,我使用Xsd2Code。Xsd2Code可以很好地处理循环引用,并且可以在VS IDE中工作,这是一个很大的优点。它还有许多您可以使用的特性,比如生成序列化/反序列化代码。但是,如果您正在生成序列化,请确保您打开GenerateXMLAttributes(否则,如果没有在所有元素上定义,则会出现排序异常)。

两者都不适合选择功能。你最终得到的是object的列表/集合,而不是你想要的类型。我建议尽可能避免在xsd中进行选择,因为这不能很好地序列化/反序列化到强类型类中。如果你不关心这个,那就不是问题。

xsd2code中的any特性反序列化为System.Xml.XmlElement,我发现这非常方便,但如果您想要强类型对象,这可能是一个问题。当允许自定义配置数据时,我经常使用any,这样XmlElement可以方便地传递给在其他地方自定义的另一个XML反序列化器。

其他回答

在我的案例中起作用的命令是:

xsd /c your.xsd 

为了一个快速和懒惰的解决方案,(并且根本不使用VS)尝试这些在线转换器:

xsd-to-xml-converter这里 这里是Xmltocsharp转换器

XSD => XML => c#类

示例XSD:

<?xml version="1.0" encoding="UTF-8" ?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">

<xs:element name="shiporder">
  <xs:complexType>
    <xs:sequence>
      <xs:element name="orderperson" type="xs:string"/>
      <xs:element name="shipto">
        <xs:complexType>
          <xs:sequence>
            <xs:element name="name" type="xs:string"/>
            <xs:element name="address" type="xs:string"/>
            <xs:element name="city" type="xs:string"/>
            <xs:element name="country" type="xs:string"/>
          </xs:sequence>
        </xs:complexType>
      </xs:element>
      <xs:element name="item" maxOccurs="unbounded">
        <xs:complexType>
          <xs:sequence>
            <xs:element name="title" type="xs:string"/>
            <xs:element name="note" type="xs:string" minOccurs="0"/>
            <xs:element name="quantity" type="xs:positiveInteger"/>
            <xs:element name="price" type="xs:decimal"/>
          </xs:sequence>
        </xs:complexType>
      </xs:element>
    </xs:sequence>
    <xs:attribute name="orderid" type="xs:string" use="required"/>
  </xs:complexType>
</xs:element>

</xs:schema>

转换为XML:

<?xml version="1.0" encoding="utf-8"?>
<!-- Created with Liquid Technologies Online Tools 1.0 (https://www.liquid-technologies.com) -->
<shiporder xsi:noNamespaceSchemaLocation="schema.xsd" orderid="string" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <orderperson>string</orderperson>
  <shipto>
    <name>string</name>
    <address>string</address>
    <city>string</city>
    <country>string</country>
  </shipto>
  <item>
    <title>string</title>
    <note>string</note>
    <quantity>3229484693</quantity>
    <price>-6894.465094196054907</price>
  </item>
  <item>
    <title>string</title>
    <note>string</note>
    <quantity>2181272155</quantity>
    <price>-2645.585094196054907</price>
  </item>
  <item>
    <title>string</title>
    <note>string</note>
    <quantity>2485046602</quantity>
    <price>4023.034905803945093</price>
  </item>
  <item>
    <title>string</title>
    <note>string</note>
    <quantity>1342091380</quantity>
    <price>-810.825094196054907</price>
  </item>
</shiporder>

转换为这个类结构:

   /* 
    Licensed under the Apache License, Version 2.0

    http://www.apache.org/licenses/LICENSE-2.0
    */
using System;
using System.Xml.Serialization;
using System.Collections.Generic;
namespace Xml2CSharp
{
    [XmlRoot(ElementName="shipto")]
    public class Shipto {
        [XmlElement(ElementName="name")]
        public string Name { get; set; }
        [XmlElement(ElementName="address")]
        public string Address { get; set; }
        [XmlElement(ElementName="city")]
        public string City { get; set; }
        [XmlElement(ElementName="country")]
        public string Country { get; set; }
    }

    [XmlRoot(ElementName="item")]
    public class Item {
        [XmlElement(ElementName="title")]
        public string Title { get; set; }
        [XmlElement(ElementName="note")]
        public string Note { get; set; }
        [XmlElement(ElementName="quantity")]
        public string Quantity { get; set; }
        [XmlElement(ElementName="price")]
        public string Price { get; set; }
    }

    [XmlRoot(ElementName="shiporder")]
    public class Shiporder {
        [XmlElement(ElementName="orderperson")]
        public string Orderperson { get; set; }
        [XmlElement(ElementName="shipto")]
        public Shipto Shipto { get; set; }
        [XmlElement(ElementName="item")]
        public List<Item> Item { get; set; }
        [XmlAttribute(AttributeName="noNamespaceSchemaLocation", Namespace="http://www.w3.org/2001/XMLSchema-instance")]
        public string NoNamespaceSchemaLocation { get; set; }
        [XmlAttribute(AttributeName="orderid")]
        public string Orderid { get; set; }
        [XmlAttribute(AttributeName="xsi", Namespace="http://www.w3.org/2000/xmlns/")]
        public string Xsi { get; set; }
    }

}

注意!考虑到这只是入门,结果显然需要改进!

很简单;只需运行(在vs命令提示符下)

xsd your.xsd /classes

(这将创建你的。cs)。但是请注意,自2.0以来,这里的大部分固有选项都没有太大变化

对于选项,使用xsd /?或参阅MSDN;例如/enableDataBinding可能很有用。

xsd.exe, Marc Gravell提到过。在我看来,这是最快的启动和运行方式。

或者如果你需要更多的灵活性/选择:

xsd2code VS插件(Codeplex)

当您使用循环引用(即类型可以直接或间接拥有自己类型的元素)时,Xsd.exe不能很好地工作。

当存在循环引用时,我使用Xsd2Code。Xsd2Code可以很好地处理循环引用,并且可以在VS IDE中工作,这是一个很大的优点。它还有许多您可以使用的特性,比如生成序列化/反序列化代码。但是,如果您正在生成序列化,请确保您打开GenerateXMLAttributes(否则,如果没有在所有元素上定义,则会出现排序异常)。

两者都不适合选择功能。你最终得到的是object的列表/集合,而不是你想要的类型。我建议尽可能避免在xsd中进行选择,因为这不能很好地序列化/反序列化到强类型类中。如果你不关心这个,那就不是问题。

xsd2code中的any特性反序列化为System.Xml.XmlElement,我发现这非常方便,但如果您想要强类型对象,这可能是一个问题。当允许自定义配置数据时,我经常使用any,这样XmlElement可以方便地传递给在其他地方自定义的另一个XML反序列化器。