`
terryfeng
  • 浏览: 504251 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

使用 xsd.exe 命令工具 将 xsd架构 生成 类文件

阅读更多

下面是标准教程 

XML 架构定义 (Xsd.exe) 工具从 XDR、XML 和 XSD 文件或者从运行库程序集中的类生成 XML 架构或公共语言运行库类。

xsd file.xdr [/outputdir:directory][/parameters:file.xml]
xsd file.xml [/outputdir:directory] [/parameters:file.xml]
xsd file.xsd {/classes | /dataset} [/element:element] 
             [/enableLinqDataSet] [/language:language] 
                          [/namespace:namespace] [/outputdir:directory] [URI:uri] 
                          [/parameters:file.xml]
xsd {file.dll | file.exe} [/outputdir:directory] [/type:typename [...]][/parameters:file.xml]

参数

参数
说明

file.extension

指定要转换的输入文件。 必须将扩展名指定为下列之一:.xdr、.xml、.xsd、.dll 或 .exe。

如果指定一个 XDR 架构文件(.xdr 扩展名),则 Xsd.exe 将 XDR 架构转换为 XSD 架构。 输出文件与 XDR 架构同名,但扩展名为 .xsd。

如果指定一个 XML 文件(.xml 扩展名),则 Xsd.exe 从文件中的数据推导出架构并产生一个 XSD 架构。 输出文件与 XML 文件同名,但扩展名为 .xsd。

如果指定一个 XML 架构文件(.xsd 扩展名),则 Xsd.exe 将为对应于 XML 架构的运行库对象生成源代码。

如果指定一个运行库程序集文件(.exe 或 .dll 扩展名),则 Xsd.exe 为该程序集中的一个或多个类型生成架构。 可以使用 /type 选项来指定为其生成架构的类型。 输出架构被命名为 schema0.xsd、schema1.xsd,依此类推。 仅当给定类型使用 XMLRoot 自定义属性指定命名空间时,Xsd.exe 才生成多个架构。

常规选项

选项
说明

/h[elp]

显示该工具的命令语法和选项。

/o[utputdir]:directory

指定输出文件的目录。 此参数只能出现一次。 默认为当前目录。

/?

显示该工具的命令语法和选项。

/P[arameters]: file.xml

从指定的 .xml 文件读取各种操作模式的选项。 缩写形式为“/p:”。 有关更多信息,请参见下面的“备注”部分。

XSD 文件选项

必须为 xsd 文件仅指定下列选项中的一个。

选项
说明

/c[lasses]

生成与指定架构相对应的类。 若要将 XML 数据读入对象,请使用 System.Xml.Serialization.XmlSerializer.Deserializer 方法。

/d[ataset]

生成一个从 DataSet 派生的类,该类与指定的架构相对应。 若要将 XML 数据读入派生类,请使用 System.Data.DataSet.ReadXml 方法。

还可以为 .xsd 文件指定下列任何选项。

选项
说明

/e[lement]:element

指定架构中要为其生成代码的元素。 默认情况下,键入所有元素。 可以多次指定该参数。

/enableDataBinding

在所有生成的类型上实现 INotifyPropertyChanged 接口以启用数据绑定。 缩写形式为“/edb”。

/enableLinqDataSet

(缩写形式:/eld。) 指定可使用 查询的生成的数据集。 此选项在同时指定 /dataset 选项的情况下使用。 有关更多信息,请参见 LINQ to DataSet Overview 和 Querying Typed DataSets。 有关使用 LINQ 的常规信息,请参见Language-Integrated Query (LINQ)。

/f[ields]

生成字段,而不是生成属性。 默认情况下生成属性。

/l[anguage]:language

指定要使用的编程语言。 从 CS(默认情况下为 C#)、VB (Visual Basic)、JS (JScript) 或 VJS (Visual J#) 中进行选择。 也可指定实现 System.CodeDom.Compiler.CodeDomProvider 的类的完全限定名

/n[amespace]:namespace

为生成的类型指定运行库命名空间。 默认命名空间为 Schemas

/nologo

取消显示版权标志。

/order

在所有粒子成员上生成显式顺序标识符。

/o[ut]: directoryName

指定要放置文件的输出目录。默认为当前目录。

/u[ri]:uri

为架构中要为其生成代码的元素指定 URI。 该 URI(如果存在)应用于使用 /element 选项指定的所有元素。

DLL 和 EXE 文件选项

选项
说明

/t[ype]:typename

指定要为其创建架构的类型的名称。 可以指定多个类型参数。 如果 typename 不指定一个命名空间,则 Xsd.exe 将程序集中的所有类型与指定类型相匹配。 如果 typename 指定一个命名空间,则仅匹配那个类型。 如果 typename 以星号字符 (*) 结尾,则此工具匹配所有以 * 前的字符串开头的类型。 如果省略 /type 选项,则 Xsd.exe 为程序集中的所有类型生成架构。

备注

下表显示了 Xsd.exe 执行的操作。

XDR 到 XSD

使用精简 XML 数据架构文件生成 XML 架构。 XDR 为早期基于 XML 的架构格式。

XML 到 XSD

使用 XML 文件生成 XML 架构。

XSD 到 DataSet

使用 XSD 架构文件生成公共语言运行库 DataSet 类。 生成的类为规则 XML 数据提供复杂对象模型。

XSD 到类

使用 XSD 架构文件生成运行库类。 生成的类可以与 System.Xml.Serialization.XmlSerializer 一起使用,来读写遵循该架构的 XML 代码。

类到 XSD

使用运行库程序集文件中的一个或多个类型生成 XML 架构。 生成的架构定义了 System.Xml.Serialization.XmlSerializer 使用的 XML 格式。

Xsd.exe 只允许操作遵循由万维网联合会 (W3C) 提议的 XML 架构定义 (XSD) 语言的 XML 架构。 有关 XML 架构定义提议或 XML 标准的更多信息,请参见 http://w3.org。

<?XML:NAMESPACE PREFIX = [default] http://ddue.schemas.microsoft.com/authoring/2003/5 NS = "http://ddue.schemas.microsoft.com/authoring/2003/5" />

Collapse image通过 XML 文件设置选项

通过使用 /parameters 开关,可指定设置各种选项的单个 XML 文件。 可设置的选项取决于您如何使用 XSD.exe 工具。 选择包括生成架构、生成代码文件,或生成包含 DataSet 功能的代码文件。 例如,生成架构时可将 <assembly> 元素设置为可执行文件 (.exe) 或类库文件 (.dll) 的名称,但生成代码文件时则不能。 下面的 XML 演示如何将 <generateSchemas> 元素用于指定的可执行文件:

复制代码

<!-- This is in a file named GenerateSchemas.xml. -->
<xsd xmlns='http://microsoft.com/dotnet/tools/xsd/'>
<generateSchemas>
   <assembly>ConsoleApplication1.exe</assembly>
</generateSchemas>
</xsd>

如果前面的 XML 包含在名为 GenerateSchemas.xml 的文件中,则通过在命令提示处键入下面的内容并按 Enter 使用 /parameters 开关:

xsd /p:GenerateSchemas.xml

另外,如果为程序集中的单个类型生成架构,则可以使用下面的 XML:

复制代码

<!-- This is in a file named GenerateSchemaFromType.xml. -->
<xsd xmlns='http://microsoft.com/dotnet/tools/xsd/'>
<generateSchemas>
   <type>IDItems</type>
</generateSchemas>
</xsd>

但是若要使用上面的代码,您还必须在命令提示处提供程序集的名称。 在命令提示处键入下面的内容(假设 XML 文件名为 GenerateSchemaFromType.xml):

xsd /p:GenerateSchemaFromType.xml ConsoleApplication1.exe

必须为 <generateSchemas> 元素仅指定以下选项中的一个。

元素
说明

<程序集>

指定将从中生成架构的程序集。

<类型>

指定程序集中找到的要为其生成架构的类型。

<xml>

指定要为其生成架构的 XML 文件。

<xdr>

指定要为其生成架构的 XDR 文件。

若要生成代码文件,请使用 <generateClasses> 元素。 下面的示例生成一个代码文件。 请注意,另外还显示了两个属性,它们允许您为生成的文件设置编程语言和命名空间。

CopyCode image复制代码

<xsd xmlns='http://microsoft.com/dotnet/tools/xsd/'>
<generateClasses language='VB' namespace='Microsoft.Serialization.Examples'/>
</xsd>
<!-- You must supply an .xsd file when typing in the command line.-->
<!-- For example: xsd /p:genClasses mySchema.xsd -->

可为 <generateClasses> 元素设置以下选项。

元素
说明

<元素>

指定 .xsd 文件中要为其生成代码的元素。

<schemaImporterExtensions>

指定派生自 SchemaImporterExtension 类的类型。

<schema>

指定要为其生成代码的 XML 架构文件。 使用多个 <schema> 元素,可以指定多个 XML 架构文件。

下表显示也可与 <generateClasses> 元素一起使用的属性。

属性
说明

language

指定要使用的编程语言。 从 CS(默认情况下为 C#)、VB (Visual Basic)、JS (JScript) 或 VJS (Visual J#) 中进行选择。 也可指定实现 CodeDomProvider 的类的完全限定名。

namespace

为生成的代码指定命名空间。 命名空间必须符合 CLR 标准(例如,没有空格或反斜杠字符)。

options

以下值之一:noneproperties(生成属性而不是公共字段)、orderenableDataBinding(请参见前面“XSD 文件选项”一节的 /order/enableDataBinding 开关)。

使用 <generateDataSets> 元素还可以控制如何生成 DataSet 代码。 下面的 XML 指定生成的代码使用 DataSet 结构(如 DataTable 类)为指定元素创建 Visual Basic 代码。 生成的数据集结构将支持 LINQ 查询。

<xsd xmlns='http://microsoft.com/dotnet/tools/xsd/'>

<generateDataSet language='VB' namespace='Microsoft.Serialization.Examples' enableLinqDataSet='true'>

</generateDataSet>

</xsd>

可为 <generateDataSet> 元素设置以下选项。

元素
说明

<schema>

指定要为其生成代码的 XML 架构文件。 使用多个 <schema> 元素,可以指定多个 XML 架构文件。

下表显示可与 <generateDataSet> 元素一起使用的属性。

属性
说明

enableLinqDataSet

指定可使用 查询的生成的数据集。 默认值为 False。

language

指定要使用的编程语言。 从 CS(默认情况下为 C#)、VB (Visual Basic)、JS (JScript) 或 VJS (Visual J#) 中进行选择。 也可指定实现 CodeDomProvider 的类的完全限定名。

namespace

为生成的代码指定命名空间。 命名空间必须符合 CLR 标准(例如,没有空格或反斜杠字符)。

有些属性可在顶级 <xsd> 元素上设置。 这些选项可用于任何子元素(<generateSchemas><generateClasses><generateDataSet>)。 下面的 XML 代码在名为“MyOutputDirectory”的输出目录中为名为“IDItems”的元素生成代码。

复制代码

<xsd xmlns='http://microsoft.com/dotnet/tools/xsd/' output='MyOutputDirectory'>
<generateClasses>
<element>IDItems</element>
</generateClasses>
</xsd>

下表显示也可用于 <xsd> 元素的属性。

属性
说明

output

将放置生成的架构或代码文件的目录的名称。

nologo

取消显示版权标志。 设置为 truefalse

help

显示该工具的命令语法和选项。 设置为 truefalse

复制代码

          

Collapse image示例

下面的命令从 myFile.xdr 生成一个 XML 架构并将它保存到当前目录中。

复制代码

xsd myFile.xdr 

下面的命令从 myFile.xml 生成一个 XML 架构并将它保存到指定目录中。

复制代码

xsd myFile.xml /outputdir:myOutputDir

下面的命令生成一个与 C# 语言中的指定架构相对应的数据集,并在当前目录中将其保存为 XSDSchemaFile.cs

复制代码

xsd /dataset /language:CS XSDSchemaFile.xsd

下面的命令为程序集 myAssembly.dll 中的所有类型生成 XML 架构,并在当前目录中将它们保存为 schema0.xsd

示例

如下图打开XSD.exe

2009-03-29_161021

  输入下面的命令:

xsd d:\TDDOWNLOAD\atom-author-link.xsd /c /language:C# /outputdir:d:\

含义:

将d:\TDDOWNLOAD\atom-author-link.xsd 架构 生成类 语言为C# 输出目录是d:\

2009-03-29_164115

结果在:D盘根目录下生成了一个名字叫 atom-author-link.cs 的类文件

 

问题:

我在用下面的语句生成的时候,Kml22bete.xsd里面有引用

<!-- import atom:author and atom:link -->
  <import namespace="http://www.w3.org/2005/Atom"
    schemaLocation="http://code.google.com/apis/kml/schema/atom-author-link.xsd"/>

  <!-- import xAL:Address -->
  <import namespace="urn:oasis:names:tc:ciq:xsdschema:xAL:2.0"
    schemaLocation="http://docs.oasis-open.org/election/external/xAL.xsd"/>

用下面的命令处理,总是会报错,如何解决呢,那位知道的朋友告诉我谢谢

C:\Program Files\Microsoft SDKs\Windows\v6.0A\bin>xsd d:\TDDOWNLOAD\kml22beta.xsd   /c /language:C# /outputdir:d:\
Microsoft(R) Xml 架构/数据类型支持实用工具
[Microsoft (R) .NET Framework, Version 2.0.50727.3038]
Copyright (C) Microsoft Corporation. All rights reserved.
架构验证警告: 未声明“http://www.w3.org/2005/Atom:author”元素。 行 354,位置 12。
架构验证警告: 未声明“http://www.w3.org/2005/Atom:link”元素。 行 356,位置 12。
架构验证警告: 未声明“urn:oasis:names:tc:ciq:xsdschema:xAL:2.0:AddressDetails”元素。 行 359,位置 12。

分享到:
评论

相关推荐

    利用wsdl.exe生成webservice代理类

    利用wsdl.exe生成webservice代理类: 根据提供的wsdl生成webservice代理类 1、开始-&gt;程序-&gt;Visual Studio 2005 命令提示 2、输入如下红色标记部分 D:\Program Files\Microsoft Visual Studio 8\VC&gt;wsdl /...

    jdk 1.6 支持架构文件直接生成po对象

    不过,通常这样的文章会详细介绍如何利用JDK 1.6的工具如`xsd.exe`来解析XSD文件并生成对应的Java类。 标签“源码”和“工具”提示我们,这篇博文可能涉及了代码示例和使用的工具。在JDK 1.6中,`xjc`是实现这一...

    xsd可视化操作

    XML Schema Definition (XSD) 是一种用于定义XML文档结构的语言,它规范了XML文档的元素、属性、数据类型以及它们之间的...通过选择合适的XSD可视化工具,并熟练掌握其使用,可以在处理XML相关项目时获得极大的便利。

    cxf所需JAR包和xsd文件

    使用CXF开发Web服务的一般步骤包括:创建XSD文件以定义服务接口,使用CXF工具生成Java类,编写服务实现,配置CXF和Spring,最后部署和测试服务。 6. **源码分析**: "apache-cxf-3.1.4-src.tar.gz"包含的源代码...

    EMF XSD SDK

    EMF XSD SDK提供了一整套工具和API,使得开发者能够轻松地将XSD文档转换为Java类,这些类可以直接在Java代码中使用,从而简化XML数据的处理。此外,它还支持XSD的验证、编辑和转换功能。 SDK中的关键组件包括: 1....

    dubbo的xsd文件

    本文将深入探讨`dubbo.xsd`文件的作用、结构以及如何使用它来配置Dubbo服务。 1. **Dubbo.xsd的用途** `dubbo.xsd`是Dubbo配置文件的规范,它定义了XML文件中可以使用的元素、属性及其约束。当开发者按照这个规范...

    xgen:XSD(XML架构定义)解析器和GoCJavaRustTypeScript代码生成器

    Xgen介绍xgen是一个用Go语言编写的库,提供了一组允许您解析XSD... 下面的命令将在xsd路径上移动,并在output目录下生成Go语言结构代码。 $ xgen -i /path/to/your/xsd -o /path/to/your/output -l Go用法: $ xgen

    Xsd转换xml

    在IT行业中,XML(eXtensible Markup Language)和XSD(XML Schema Definition)是用于数据交换和结构化数据描述的重要工具。XML是一种标记语言,它允许我们在文档中定义和组织结构化的数据,而XSD则是一种规范,...

    excel读取生成xml文件

    6. **测试和验证**:为了确保生成的XML文件符合预期,可以使用XML验证工具,如XML Schema Definition (XSD) 或者 Relax NG,来检查文件是否符合定义的模式。 在压缩包文件“testXmlExcel”中,可能包含了示例的...

    xsd2xml:来自xsd的python轻量级xml生成器

    它使用库解析给定的架构文档,然后填充一些硬编码的值。 请检查以下示例。 XSD &lt;? xml version = " 1.0 " encoding = " utf-8 " ?&gt; &lt; xs : element name = " empno " type = " xs:string " /

    CodeSmith

    `csxsd.exe`可能是用来处理XML Schema文档的,因为`xsd`通常与XML Schema设计和生成有关。 `license.rtf`包含了软件的许可协议信息,用户在使用前应仔细阅读,确保遵循软件的使用条款。`history.txt`可能记录了软件...

    XeroAPI架构:api.xero.com的XSD架构

    3. **创建Java对象**:根据XSD定义,使用JAXB或其他库生成对应的Java类,这些类将作为与API交互的数据模型。 4. **构建请求**:使用这些Java对象构建符合API要求的XML请求。 5. **发送请求**:通过HTTP客户端(如...

    XML生成工具,匹配固定格式

    1. **定义XML架构(DTD或XSD)**:为了确保生成的XML符合特定格式,需要先定义一个文档类型定义(DTD)或XML Schema(XSD)。这些定义了元素、属性和它们的约束,如同一种“蓝图”。 2. **创建XML文档对象模型(DOM...

    对象关系映射架构(DBFrameworkV4.5.1)及代码生成器

    不用編寫SQL語句或存儲過程即可實現下列功能: 1、數據表、試... &lt;br&gt;提供 1、对象关系映射组件: Kenly.DBFramework.dll 2、代码生成器:Xsd2CS.exe 3、范例:数据库脚本、ASP.NET工程 4、使用手册。

    C#xml操作示例

    通过使用xsd.exe工具,可以将现有的XML文档转换为XSD,反之亦然。这确保了XML数据遵循预定义的规范,增强了数据的可靠性。 总结来说,C#中的XML操作涉及到加载和解析XML文件,使用XPath查询和修改节点,利用LINQ to...

    gsoap 2.8 (SOAP/XML 关于C/C++ 语言的自动化实现工具内附 CSharp webservice例子,及GSOAP client和server例子)

    gSOAP编译工具提供了一个SOAP/XML 关于C/C++ 语言的实现,从而让C/C++语言开发web...3. 如果webservice是php的 请注意修改php版wsdl中类型为标准类型(默认好像php生成的wsdl文件某些类型未做指定, 如xsd:string之类的)

    C++环境下使用gsoap开发WebService接口操作指南

    wsdl2h.exe用来将wsdl文件转换为头文件,而soapcpp2.exe用来根据接口头文件生成应用程序客户端和服务端的框架文件。 在使用gsoap时,需要生成头文件,可以通过两种方式得到:一是由现有的wsdl文件转换得到,使用...

    ajax调用java实例源码-xsd-forms:从xml架构文档(xsd)生成Web表单

    ajax调用java实例源码xsd 表格 您想要制作一个提交结构化数据 (XML/JSON) 的 Web 表单。 xsd-forms基于已用一些表示信息注释的 xml 模式 (XSD) 为您生成 Web 表单。 xsd-forms已被部署到一个免费可用的环境中,以...

    doc2x_r649.zip

    4. **XML验证和优化**:生成的XML文件可能需要通过验证,以确保其符合预定义的XML架构(如XSD),并进行可能的优化,如压缩重复的数据,去除不必要的空格和换行,以减小文件大小并提高处理效率。 5. **支持批量转换...

Global site tag (gtag.js) - Google Analytics