Ключевое слово is
- это тест для идентификации объекта, а ==
- сравнение значений.
Если вы используете is
, результат будет истинным тогда и только тогда, когда объект является тот же объект. Однако ==
будет истинным в любое время, когда значения объекта будут одинаковыми.
Вероятно, просто стоит поймать определенное исключение, если Вы хотите показать сообщение пользователю:
try
{
XDocument xd1 = new XDocument();
xd1 = XDocument.Load(myfile);
}
catch (XmlException exception)
{
ShowMessage("Your XML was probably bad...");
}
Этот вопрос путает" правильно построенный " с" допустимый " XML-документ .
, действительный xml документ является по определению хорошо сформированным документом. Дополнительно , должно удовлетворить DTD или схема ( схема XML , расслабляющая схема , schematron или другие ограничения ) быть допустимым.
Оценка от формулировки вопроса, по всей вероятности это спрашивает:
, "Как удостовериться, файл содержит правильно построенный XML-документ?".
ответ - то, что XML-документ правильно построен, если он может быть проанализирован успешно совместимым синтаксическим анализатором XML. Как XDocument. Загрузка () метод делает точно это, только необходимо поймать исключение и затем прийти к заключению, что текст, содержавшийся в файле, не хорошо формируется.
Просто загрузите его и поймайте исключение. То же для File.Exists()
- файловая система энергозависима поэтому просто, потому что File.Exists()
возвращает true, не означает, что Вы сможете открыть его.
Если у Вас есть XSD для XML, попробуйте это:
using System;
using System.Xml;
using System.Xml.Schema;
using System.IO;
public class ValidXSD
{
public static void Main()
{
// Set the validation settings.
XmlReaderSettings settings = new XmlReaderSettings();
settings.ValidationType = ValidationType.Schema;
settings.ValidationFlags |= XmlSchemaValidationFlags.ProcessInlineSchema;
settings.ValidationFlags |= XmlSchemaValidationFlags.ReportValidationWarnings;
settings.ValidationEventHandler += new ValidationEventHandler(ValidationCallBack);
// Create the XmlReader object.
XmlReader reader = XmlReader.Create("inlineSchema.xml", settings);
// Parse the file.
while (reader.Read());
}
// Display any warnings or errors.
private static void ValidationCallBack (object sender, ValidationEventArgs args)
{
if (args.Severity == XmlSeverityType.Warning)
Console.WriteLine("\tWarning: Matching schema not found. No validation occurred." + args.Message);
else
Console.WriteLine("\tValidation error: " + args.Message);
}
}
Ссылка здесь:
http://msdn.microsoft.com/en-us/library/system.xml.xmlreadersettings.validationeventhandler.aspx
Как был ранее упомянут "допустимый xml", тестируется XmlDocument. Загрузка (). Просто поймайте исключение. При необходимости в дальнейшей проверке для тестирования этого, это допустимо против схемы, то это делает то, что Вы после:
using System.Xml;
using System.Xml.Schema;
using System.IO;
static class Program
{
private static bool _Valid = true; //Until we find otherwise
private static void Invalidated()
{
_Valid = false;
}
private static bool Validated(XmlTextReader Xml, XmlTextReader Xsd)
{
var MySchema = XmlSchema.Read(Xsd, new ValidationEventHandler(Invalidated));
var MySettings = new XmlReaderSettings();
{
MySettings.IgnoreComments = true;
MySettings.IgnoreProcessingInstructions = true;
MySettings.IgnoreWhitespace = true;
}
var MyXml = XmlReader.Create(Xml, MySettings);
while (MyXml.Read) {
//Parsing...
}
return _Valid;
}
public static void Main()
{
var XsdPath = "C:\\Path\\To\\MySchemaDocument.xsd";
var XmlPath = "C:\\Path\\To\\MyXmlDocument.xml";
var XsdDoc = new XmlTextReader(XsdPath);
var XmlDoc = new XmlTextReader(XmlPath);
var WellFormed = true;
XmlDocument xDoc = new XmlDocument();
try {
xDoc.Load(XmlDoc);
}
catch (XmlException Ex) {
WellFormed = false;
}
if (WellFormed & Validated(XmlDoc, XsdDoc)) {
//Do stuff with my well formed and validated XmlDocument instance...
}
}
}