Altova XMLSpy 2023 Enterprise Edition

从XML Schema类型到C#数据类型的默认映射如下:

 

XML Schema

C#

备注

xs:string

字符串


xs:boolean

bool


xs:decimal

decimal

xs:decimal没有范围和精度限制,映射到decimal以提高效率。

xs:float, xs:double

double


xs:long

long


xs:unsignedLong

ulong


xs:int

int


xs:unsignedInt

uint


xs:dateTime, date, time, gYearMonth, gYear, gMonthDay, gDay, gMonth

Altova.Types.DateTime


xs:duration

Altova.Types.Duration


xs:hexBinary and xs:base64Binary

byte[]

二进制数据的编码和解码都是自动完成的。

xs:anySimpleType

字符串


 

未包含在列表中的所有XML Schema类型都是派生类型,并且映射到与相应基类型相同的C#类型。

 

生成的类

为Schema中的每个类型都会生成一个类,其中包含该类型的每个属性和元素的成员。这些成员被赋予与原始Schema中的特性或元素相同的名称(为了避免可能的冲突,追加了一个数字)。对于简单类型,将生成赋值和转换运算符。对于具有枚举方面的简单类型,可以使用GetEnumerationValue()SetEnumerationValue(int)方法以及为每个枚举值生成的常量。此外,还可以使用StaticInfo()方法通过以下类型之一访问Schema信息:

 

Altova.Xml.Meta.SimpleType

Altova.Xml.Meta.ComplexType

 

从复杂类型生成的类包含SetXsiType()方法,它允许您设置该类型的xsi:type特性。当您想从派生类型创建XML实例元素时这一方法将十分有用。

 

除了在XML Schema中声明的类型的类以外,还会生成一个文档类(在下文中用“Doc”标识)。它包含所有可能的根元素作为成员,以及各自其他方法。有关该类的更多信息,请参见[YourSchema].[Doc]

 

提示:        实际的类名称取决于.xsd schema的名称。

 

对于Schema类型的每个成员特性或元素,将生成一个新的类。有关该类的更多信息,请参见:

 

[YourSchemaType].MemberAttribute

[YourSchemaType].MemberElement

 

提示:        实际的类名取决于Schema特性或元素的名称。

 

处理错误

错误由异常报告。在命名空间Altova中定义了以下异常类:

 

Class

基类

描述

ConversionException

Exception

类型转换失败导致出现异常。

StringParseException

ConversionException

词法空间中的值无法转换为值空间。

DataSourceUnavailableException

System.Exception

加载XML实例时出现问题。

DataTargetUnavailableException

System.Exception

保存XML实例时出现问题。

 

此外,通常使用以下.NET异常:

 

Class

描述

System.Exception

运行时错误的基类。

System.ArgumentException

使用无效的参数值调用了一个方法,或类型转换失败。

System.FormatException

词法空间中的值无法转换为值空间。

System.InvalidCastException

值无法转换为另一个类型。

System.OverflowException

无法在目标域中表示源值。

 

访问Schema信息

可以使用生成的库通过以下类访问静态Schema信息。

 

Altova.Xml.Meta.Attribute

Altova.Xml.Meta.ComplexType

Altova.Xml.Meta.Element

Altova.Xml.Meta.SimpleType

 

如果不存在相应的属性,则返回任何元数据类的属性会返回NULL。

© 2017-2023 Altova GmbH