XmlSchemaDatatype.ParseValue Метод
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Перегрузки
ParseValue(String, XmlNameTable, IXmlNamespaceResolver) |
При переопределении в производном классе выполняется проверка заданного |
ParseValue(String, XmlNameTable, XmlNamespaceManager) |
При переопределении в производном классе проверяет заданную строку на соответствие встроенному или пользовательскому простому типу. |
ParseValue(String, XmlNameTable, IXmlNamespaceResolver)
При переопределении в производном классе выполняется проверка заданного string
на соответствие со встроенным или пользовательским простым типом.
public:
abstract System::Object ^ ParseValue(System::String ^ s, System::Xml::XmlNameTable ^ nameTable, System::Xml::IXmlNamespaceResolver ^ nsmgr);
public abstract object ParseValue (string s, System.Xml.XmlNameTable? nameTable, System.Xml.IXmlNamespaceResolver? nsmgr);
public abstract object ParseValue (string s, System.Xml.XmlNameTable nameTable, System.Xml.IXmlNamespaceResolver nsmgr);
abstract member ParseValue : string * System.Xml.XmlNameTable * System.Xml.IXmlNamespaceResolver -> obj
Public MustOverride Function ParseValue (s As String, nameTable As XmlNameTable, nsmgr As IXmlNamespaceResolver) As Object
Параметры
- s
- String
string
, чтобы проверить на соответствие простому типу.
- nameTable
- XmlNameTable
XmlNameTable, чтобы использовать для атомизации при синтаксическом разборе string
, если данный объект XmlSchemaDatatype представляет тип xs:NCName.
- nsmgr
- IXmlNamespaceResolver
Объект IXmlNamespaceResolver для использования при синтаксическом разборе string
, если данный объект XmlSchemaDatatype представляет тип xs:QName.
Возвращаемое значение
Object, который может быть безопасно приведен к типу, возвращаемому свойством ValueType.
Исключения
Входное значение не является допустимым экземпляром типа W3C XML-схемы.
Значение для разбора не может являться null
.
Примеры
В следующем примере из файла example.xsd извлекается простой LotteryNumber
тип, а затем проверяется string
значение 5
использования ParseValue метода.XmlSchemaSimpleType
#using <mscorlib.dll>
#using <System.Xml.dll>
using namespace System;
using namespace System::Xml;
using namespace System::Xml::Schema;
class XmlSchemaExamples
{
public:
static void Main()
{
XmlTextReader^ xtr = gcnew XmlTextReader("example.xsd");
XmlSchema^ schema = XmlSchema::Read(xtr, gcnew ValidationEventHandler(ValidationCallbackOne));
XmlSchemaSet^ schemaSet = gcnew XmlSchemaSet();
schemaSet->ValidationEventHandler += gcnew ValidationEventHandler(ValidationCallbackOne);
schemaSet->Add(schema);
schemaSet->Compile();
XmlSchema^ compiledSchema;
for each (XmlSchema^ schema1 in schemaSet->Schemas())
{
compiledSchema = schema1;
}
for each (XmlSchemaObject^ schemaObject in compiledSchema->Items)
{
if (schemaObject->GetType() == XmlSchemaSimpleType::typeid)
{
XmlSchemaSimpleType^ simpleType = dynamic_cast<XmlSchemaSimpleType^>(schemaObject);
Console::WriteLine("{0} {1}", simpleType->Name, simpleType->Datatype->ValueType);
}
if (schemaObject->GetType() == XmlSchemaComplexType::typeid)
{
XmlSchemaComplexType^ complexType = dynamic_cast<XmlSchemaComplexType^>(schemaObject);
Console::WriteLine("{0} {1}", complexType->Name, complexType->Datatype->ValueType);
}
}
xtr->Close();
}
static void ValidationCallbackOne(Object^ sender, ValidationEventArgs^ args)
{
Console::WriteLine(args->Message);
}
};
int main()
{
XmlSchemaExamples::Main();
return 0;
};
using System;
using System.Xml;
using System.Xml.Schema;
class XMLSchemaExamples
{
public static void Main()
{
XmlTextReader xtr = new XmlTextReader("example.xsd");
XmlSchema schema = XmlSchema.Read(xtr, new ValidationEventHandler(ValidationCallbackOne));
XmlSchemaSet schemaSet = new XmlSchemaSet();
schemaSet.ValidationEventHandler += new ValidationEventHandler(ValidationCallbackOne);
schemaSet.Add(schema);
schemaSet.Compile();
XmlSchema compiledSchema = null;
foreach (XmlSchema schema1 in schemaSet.Schemas())
{
compiledSchema = schema1;
}
foreach (XmlSchemaObject schemaObject in compiledSchema.Items)
{
if (schemaObject.GetType() == typeof(XmlSchemaSimpleType))
{
XmlSchemaSimpleType simpleType = (XmlSchemaSimpleType)schemaObject;
Console.WriteLine("{0} {1}", simpleType.Name, simpleType.Datatype.ValueType);
}
if (schemaObject.GetType() == typeof(XmlSchemaComplexType))
{
XmlSchemaComplexType complexType = (XmlSchemaComplexType)schemaObject;
Console.WriteLine("{0} {1}", complexType.Name, complexType.Datatype.ValueType);
}
}
xtr.Close();
}
public static void ValidationCallbackOne(object sender, ValidationEventArgs args)
{
Console.WriteLine(args.Message);
}
}
Imports System.Xml
Imports System.Xml.Schema
_
Class XMLSchemaExamples
Public Shared Sub Main()
Dim xtr As New XmlTextReader("example.xsd")
Dim schema As XmlSchema = XmlSchema.Read(xtr, New ValidationEventHandler(AddressOf ValidationCallbackOne))
Dim schemaSet As New XmlSchemaSet()
AddHandler schemaSet.ValidationEventHandler, AddressOf ValidationCallbackOne
schemaSet.Add(schema)
schemaSet.Compile()
Dim compiledSchema As XmlSchema = Nothing
For Each schema1 As XmlSchema In schemaSet.Schemas()
compiledSchema = schema1
Next
Dim schemaObject As XmlSchemaObject
For Each schemaObject In compiledSchema.Items
If schemaObject.GetType() Is GetType(XmlSchemaSimpleType) Then
Dim simpleType As XmlSchemaSimpleType = CType(schemaObject, XmlSchemaSimpleType)
Console.WriteLine("{0} {1}", simpleType.Name, simpleType.Datatype.ValueType)
End If
If schemaObject.GetType() Is GetType(XmlSchemaComplexType) Then
Dim complexType As XmlSchemaComplexType = CType(schemaObject, XmlSchemaComplexType)
Console.WriteLine("{0} {1}", complexType.Name, complexType.Datatype.ValueType)
End If
Next schemaObject
xtr.Close()
End Sub
Public Shared Sub ValidationCallbackOne(ByVal sender As Object, ByVal args As ValidationEventArgs)
Console.WriteLine(args.Message)
End Sub
End Class
Следующий XML-файл используется для предыдущего примера кода.
<?xml version="1.0"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:simpleType name="LotteryNumber">
<xs:restriction base="xs:int">
<xs:minInclusive value="1"/>
<xs:maxInclusive value="99"/>
</xs:restriction>
</xs:simpleType>
</xs:schema>
Комментарии
Метод ParseValue проверяет указанный string
тип на соответствие встроенному или определяемого пользователем простому типу. Например, если это XmlSchemaDatatype представляет тип xs:date, возвращается экземпляр DateTime .
Ниже приведены шаги, выполняемые во время ParseValue проверки метода.
Преобразуйте значение, указанное в качестве соответствующего
string
типа среды CLR.Убедитесь, что значение не нарушает никаких аспектов, определенных для простого типа.
Преобразованное значение возвращается в виде объекта Object и может быть безопасно приведено к типу, возвращаемого свойством ValueType .
XmlSchemaDatatype Когда объект представляет тип списка, входное string
значение преобразуется в список одного или нескольких объектов. XmlSchemaDatatype Когда объект представляет тип списка, предпринимается попытка проанализировать входное значение как тип элемента объединения. Если попытка синтаксического анализа завершается ошибкой, преобразование выполняется с помощью следующего члена объединения до тех пор, пока синтаксический анализ не будет выполнен успешно или нет других типов элементов для синтаксического анализа. Если синтаксический анализ завершается неудачно, возникает исключение.
Применяется к
ParseValue(String, XmlNameTable, XmlNamespaceManager)
При переопределении в производном классе проверяет заданную строку на соответствие встроенному или пользовательскому простому типу.
public:
abstract System::Object ^ ParseValue(System::String ^ s, System::Xml::XmlNameTable ^ nameTable, System::Xml::XmlNamespaceManager ^ nsmgr);
public abstract object ParseValue (string s, System.Xml.XmlNameTable nameTable, System.Xml.XmlNamespaceManager nsmgr);
abstract member ParseValue : string * System.Xml.XmlNameTable * System.Xml.XmlNamespaceManager -> obj
Public MustOverride Function ParseValue (s As String, nameTable As XmlNameTable, nsmgr As XmlNamespaceManager) As Object
Параметры
- s
- String
Строка, чтобы проверить на соответствие простому типу.
- nameTable
- XmlNameTable
XmlNameTable, чтобы использовать для атомизации при синтаксическом разборе строки, если данный объект XmlSchemaDatatype представляет тип xs:NCName.
- nsmgr
- XmlNamespaceManager
Объект XmlNamespaceManager для использования при синтаксическом разборе строки, если данный объект XmlSchemaDatatype представляет тип xs:QName.
Возвращаемое значение
Объект Object, который может быть безопасно приведен к типу, возвращаемому свойством ValueType.
Исключения
Входное значение не является допустимым экземпляром типа W3C XML-схемы.
Значение для анализа не может быть NULL (Nothing в Visual Basic).
Комментарии
Метод ParseValue проверяет указанную строку на соответствие встроенному или определяемого пользователем простому типу. Например, если это XmlSchemaDatatype представляет тип xs:date, возвращается экземпляр DateTime .
Ниже приведены шаги, выполняемые во время ParseValue проверки метода.
Преобразуйте указанную строку в соответствующий тип среды CLR.
Убедитесь, что значение не нарушает никаких аспектов, определенных для простого типа.
Преобразованное значение возвращается в виде значения Object и может быть безопасно приведено к типу, возвращаемого свойством ValueType .
XmlSchemaDatatype Если объект представляет тип списка, входное строковое значение преобразуется в список одного или нескольких объектов. XmlSchemaDatatype Когда объект представляет тип списка, предпринимается попытка проанализировать входное значение как тип элемента объединения. Если попытка синтаксического анализа завершается ошибкой, преобразование выполняется с помощью следующего члена объединения до тех пор, пока синтаксический анализ не будет выполнен успешно или нет других типов элементов для синтаксического анализа. Если синтаксический анализ завершается неудачно, возникает исключение.