vxml解析,vue 解析xml

http://www.itjxue.com  2023-01-21 09:15  来源:未知  点击次数: 

在VS上发布网站在本机,在IIS上点击浏览时出现:XML解析错误:未找到元素位置,是什么问题啊?急!!

嗯 这个是有一次在重新安装服务器的时候有遇到过后面重新注册了下IIS就可以了

C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727\aspnet_regiis.exe -i

地址换成你安装地址啊 亲

javascript解析xml文件出错

首先你要确定是否加载到资源了,你可以alert(xmlDoc.xml)试一下,

还有一个

var

v

=

xmlDoc.getElementsByTagName('Login/Weapon/W')[0].childNodes.getAttribute('Text');

你这句话是错的,

getElementByTagName是根据标签的名称获取到标签的,

而你写的的是(Login/Weapon/W)

这个是标签的完整路径

你应该这么些xmlDoc.selectSingleNode("Login/Weapon/W")

script

type="text/javascript"

var

xmlDoc

=

new

ActiveXObject("Microsoft.XMLDOM");

xmlDoc.async

=

false;

xmlDoc.load("login.xml");

var

v

=

xmlDoc.selectSingleNode("Login/Weapon/W/@Text").;

document.writeln(v);

/script

这个是那段javascript代码,这段代码是没有错的,我在load其他的xml文件的时候都是没有错的,但是load

login.xml的时候就是加载不出来,你看看你的xml文件有没有错误

请问大佬有MSXML(微软xml解析器) V4.0软件百度云资源吗

链接:

提取码:qds9

软件名称:MSXML(微软xml解析器)V4.0

语言:简体中文

大小:1.88MB

类别:系统工具

介绍:MSXML包含SDK软件开发套件,这是微软公司所释出的,安装过「神话世纪」的朋友就会知道,它已经被应用于最新的游戏。

android中怎么解析复杂的xml文件

本文主要讲解Android开发中如何对XML文件的解析,由于XML文件具有与平台无关,广泛应用于数据通信中,因此解析XML文件就显得很有意义。Android对XML文件解析的方法主要有3种。 通常有三种方式:DOM、SAX和PULL,下面就分别针对这三种方式来进行讨论。

文件内容如下所示:

那么就是要对此XML文件做解析。下面我们就分别用DOM,SAX和PULL三种方式,分别对此XML文件做解析。

DOM方式

DOM方式解析xml是先把xml文档都读到内存中,然后再用DOM API来访问树形结构,并获取数据。由DOM解析的方式可以知道,如果XML文件很大的时候,处理效率就会变得比较低,这也是DOM方式的一个缺点。

现在我们来解析上文中提到的有关天气预报信息相关的xml文件。什么是解析呢?说的通俗一点,就是将这个带标签的XML文件识别出来,并抽取一些相关的,对我们有用的信息来给我们使用。那在这个文件里,时间,天气,温度,以及图标对我们来说是需要得到的。我们要对其做解析。

解析的具体思路是:

1. 将XML文件加载进来。

2. 获取文档的根节点

3. 获取文档根节点中所有子节点的列表

4. 获取子节点列表中需要读取的节点信息

根据这4个步骤,我们进行开发:

首先就是如何加载XML文件,假设此文件来源于网络。

SAX方式

SAX是Simple API for XML的缩写。是一个包也可以看成是一些接口。

相比于DOM而言SAX是一种速度更快,更有效,占用内存更少的解析XML文件的方法。它是逐行扫描,可以做到边扫描边解析,因此SAX可以在解析文档的任意时刻停止解析。非常适用于Android等移动设备。

SAX是基于事件驱动的。所谓事件驱动就是说,它不用解析完整个文档,在按内容顺序解析文档过程中,SAX会判断当前读到的字符是否符合XML文件语法中的某部分。如果符合某部分,则会触发事件。所谓触发事件,就是调用一些回调方法。当然android的事件机制是基于回调方法的,在用SAX解析xml文档时候,在读取到文档开始和结束标签时候就会回调一个事件,在读取到其他节点与内容时候也会回调一个事件。在SAX接口中,事件源是org.xml.sax包中的XMLReader,它通过parser()方法来解析XML文档,并产生事件。事件处理器是org.xml.sax包中ContentHander、DTDHander、ErrorHandler,以及EntityResolver这4个接口。

这四个接口的详细说明如下:

事件处理器名称

事件处理器处理的事件

XMLReader注册方法

ContentHander

XML文档的开始与结束,

XML文档标签的开始与结束,接收字符数据,跳过实体,接收元素内容中可忽略的空白等。

setContentHandler(ContentHandler h)

DTDHander

处理DTD解析时产生的相应事件

setDTDHandler(DTDHandler h)

ErrorHandler

处理XML文档时产生的错误

setErrorHandler(ErrorHandler h)

EntityResolver

处理外部实体

setEntityResolver(EntityResolver e)

我们用来做内容解析的回调方法一般都定义在ContentHandler接口中。

ContentHandler接口常用的方法:

startDocument()

当遇到文档的开头的时候,调用这个方法,可以在其中做一些预处理的工作。

endDocument()

当文档结束的时候,调用这个方法,可以在其中做一些善后的工作。

startElement(String namespaceURI, String localName,String qName, Attributes atts)

当读到开始标签的时候,会调用这个方法。namespaceURI就是命名空间,localName是不带命名空间前缀的标签名,qName是带命名空间前缀的标签名。通过atts可以得到所有的属性名和相应的值。

endElement(String uri, String localName, String name)

在遇到结束标签的时候,调用这个方法。

characters(char[] ch, int start, int length)

这个方法用来处理在XML文件中读到的内容。例如:high data="30"/主要目的是获取high标签中的值。

第一个参数用于存放文件的内容,后面两个参数是读到的字符串在这个数组中的起始位置和长度,使用new String(ch,start,length)就可以获取内容。

注意:

SAX的一个重要特点就是它的流式处理,当遇到一个标签的时候,它并不会纪录下之前所碰到的标签,即在startElement()方法中,所有能够知道的信息,就是标签的名字和属性,至于标签的嵌套结构,上层标签的名字,是否有子元属等等其它与结构相关的信息,都是不知道的,都需要你的程序来完成。这使得SAX在编程处理上没有DOM方便。

现在我们截取一段XML文件来做解析,其调用方法是这样的:

?xml version="1.0"? ---------- startDocument()

weather ---------- startElement

forecast_information ---------- startElement

city ---------- startElement

beijing ---------- characters

/city ---------- endElement

/forecast_information ---------- endElement

/weather ---------- endElement

文档结束 ---------- endDocument()

SAX的解析步骤:

首先需要注意的是:

SAX还为其制定了一个Helper类:DefaultHandler它实现了ContentHandler这个接口,但是其所有的方法体都为空,在实现的时候,你只需要继承这个类,然后重载相应的方法即可。

使用SAX解析XML文件一般有以下五个步骤:

1、创建一个SAXParserFactory对象;

2、调用SAXParserFactory中的newSAXParser方法创建一个SAXParser对象;

3、然后在调用SAXParser中的getXMLReader方法获取一个XMLReader对象;

4、实例化一个DefaultHandler对象

5、连接事件源对象XMLReader到事件处理类DefaultHandler中

6、调用XMLReader的parse方法从输入源中获取到的xml数据

7、通过DefaultHandler返回我们需要的数据集合。

我们仍然来解析上述那个天气预报的XML文件。

编写代码如下:

[java] view plaincopy

mySAX.setOnClickListener(new Button.OnClickListener(){

@Override

public void onClick(View v) {

try{

String url = ";weather=beijing";

DefaultHttpClient client = new DefaultHttpClient();

HttpUriRequest req = new HttpGet(url);

HttpResponse resp = client.execute(req);

HttpEntity ent = resp.getEntity();

InputStream stream = ent.getContent(); //将文件导入流,因此用InputStream

SAXParserFactory saxFactory = SAXParserFactory.newInstance(); //获取一个对象

SAXParser saxParser = saxFactory.newSAXParser();//利用获取到的对象创建一个解析器

XMLContentHandler handler = new XMLContentHandler();//设置defaultHandler

saxParser.parse(stream, handler);//进行解析

stream.close();//关闭流

/*XMLReader xmlReader = saxFactory.newSAXParser().getXMLReader(); //获取一个XMLReader

xmlReader.setContentHandler(handler);

xmlReader.parse(new InputSource(stream));

stream.close();*/

}catch(Exception e){

e.printStackTrace();

}

}

});

}

public class XMLContentHandler extends DefaultHandler {

private static final String TAG = "XMLContentHandler";

@Override

public void characters(char[] ch, int start, int length)

throws SAXException {

Log.i(TAG, "解析内容:"+new String(ch,start,length));

}

@Override

public void endDocument() throws SAXException {

super.endDocument();

Log.i(TAG, "文档解析完毕。");

}

@Override

public void endElement(String uri, String localName, String qName)

throws SAXException {

Log.i(TAG, localName+"解析完毕");

}

@Override

public void startDocument() throws SAXException {

Log.i(TAG, "开始解析... ...");

}

@Override

public void startElement(String uri, String localName, String qName,

Attributes attributes) throws SAXException {

Log.i(TAG, "解析元素:"+localName);

if(localName.equals("high")){

Log.i(TAG, "解析元素:"+localName);

i++;

if(i==2){

highestTmp.setText(String.valueOf((Integer.parseInt(attributes.getValue(0))-32)*5/9));

}

}

}

}

上面的那段注释:

[java] view plaincopy

/*XMLReader xmlReader =saxFactory.newSAXParser().getXMLReader(); //获取一个XMLReader

xmlReader.setContentHandler(handler);

xmlReader.parse(newInputSource(stream));

stream.close();*/

是用XMLReader来做解析的另外一种方法。效果是一样的。这里可以传流,也可以传一个字符串,如下所示:是传字符串。

[java] view plaincopy

xmlReader.parse(new InputSource(new StringReader(xmlStr)));

PULL方式

除了可以使用 SAX和DOM解析XML文件,也可以使用Android内置的Pull解析器解析XML文件。 Pull解析器的运行方式与 SAX 解析器相似。它也是事件触发的。Pull解析方式让应用程序完全控制文档该怎么样被解析。比如开始和结束元素事件,使用parser.next()可以进入下一个元素并触发相应事件。通过Parser.getEventType()方法来取得事件的代码值,解析是在开始时就完成了大部分处理。事件将作为数值代码被发送,因此可以使用一个switch对感兴趣的事件进行处理。

Pull解析是一个遍历文档的过程,每次调用next(),nextTag(), nextToken()和nextText()都会向前推进文档,并使Parser停留在某些事件上面,但是不能倒退。然后把文档设置给Parser。

Android中对Pull方法提供了支持的API,主要是

org.xmlpull.v1.XmlPullParser;

org.xmlpull.v1.XmlPullParserFactory;

二个类,其中主要使用的是XmlPullParser,XmlPullParserFactory是一个工厂,用于构建XmlPullParser对象。

应用程序通过调用XmlPullParser.next()等方法来产生Event,然后再处理Event。

我们仍然拿上述天气预报的XML文件的一部分来做例子。

例如:需要解析的XML文件是:

[java] view plaincopy

forecast_conditions

day_of_week data="周三"/

low data="22"/

high data="29"/

icon data="/ig/images/weather/chance_of_rain.gif"/

condition data="可能有雨"/

/forecast_conditions

这部分XML文件中day_of_week,low,high等是TAG,data是ATTRIBUTEA。当然,如果有/夹在开始和结束符号之间的部分,则为TXET。

要想解析文档先要构建一个XmlPullParser对象。

[java] view plaincopy

final XmlPullParserFactory factory = XmlPullParserFactory.newInstance();

factory.setNamespaceAware(true);

final XmlPullParser parser = factory.newPullParser();

parser.setInput(new StringReader("xmlStr");

这里的xmlStr就是上边的XML文件。

此时,文档刚被初始化,所以它应该位于文档的开始,事件为START_DOCUMENT,可以通过XmlPullParser.getEventType()来获取。然后调用next()会产生

START_TAG,这个事件告诉应用程序一个标签已经开始了,调用getName()会返回" day_of_week ";若有TEXT,则再next()会产生TEXT事件,调用getText()会返回TEXT,由于此处没有,所以再next(),会产生END_TAG,这个告诉你一个标签已经处理完了,再next()直到最后处理完TAG,会产生END_DOCUMENT,它告诉你整个文档已经处理完成了。除了next()外,nextToken()也可以使用,只不过它会返回更加详细的事件,比如COMMENT, CDSECT, DOCDECL, ENTITY等等非常详细的信息。如果程序得到比较底层的信息,可以用nextToken()来驱动并处理详细的事件。需要注意一点的是TEXT事件是有可能返回空白的White Spaces比如换行符或空格等。

nextTag()--会忽略White Spaces,如果可以确定下一个是START_TAG或END_TAG,就可以调用nextTag()直接跳过去。通常它有二个用处:当START_TAG时,如果能确定这个TAG含有子TAG,那么就可以调用nextTag()产生子标签的START_TAG事件;当END_TAG时,如果确定不是文档结尾,就可以调用nextTag()产生下一个标签的START_TAG。在这二种情况下如果用next()会有TEXT事件,但返回的是换行符或空白符。

nextText()--只能在START_TAG时调用。当下一个元素是TEXT时,TEXT的内容会返回;当下一个元素是END_TAG时,也就是说这个标签的内容为空,那么空字串返回;这个方法返回后,Parser会停在END_TAG上。

小结一下,如果在一个XML文档中我们只需要前面一部分数据,但是使用SAX方式或DOM方式会对整个文档进行解析,尽管XML文档中后面的大部分数据我们其实都不需要解析,因此这样实际上就浪费了处理资源。使用PULL方式正合适。

当点击三种方式的任何一个按钮时,均能够得到相同的结果

如何用VBA解析XML问题,怎么解决

XML也是储存数据的一种常用形式,这节来看下从XML文件中取数据的一般方法。

一般来说,如果你的XML文件结构比较规整的话可以用Excel自带的功能来直接导入XML形式的文件,在开发工具菜单XML组中找导入,非常方便,今天我们主要来看怎样用VBA来处理XML文件。

现在我手上有一个名为Rawdata.xml的XML文件,现在我想要把该文件中所有的数据都取到Excel中,直接看代码

Private Sub OpenXml1()

Dim objDOM, n, nodes As Object, ns, i, j

Set objDOM = CreateObject("MSXML.DOMDocument")

objDOM.Load (ThisWorkbook.Path "\Rawdata.xml")

objDOM.async = False

Set ns = objDOM.SelectNodes("//extraction") '取节点extraction,即行

Set n = objDOM.SelectSingleNode("//extraction") '取单个Extraction,其长度即列

For i = 1 To ns.Length

For j = 1 To n.ChildNodes.Length

Cells(i, j) = ns.Item(i - 1).ChildNodes(j - 1).Text

Next

Next

Debug.Print n.ChildNodes.Length

Debug.Print ns.Length

Debug.Print ns.Item(0).Text

Set objDOM = Nothing

End Sub

代码稍微解释一下,先建立一个DOM对象,然后用Load方法将XML文件内容载入。选取节点用的是SelectNodes,该XML文件中行标签是extraction,所以我选择了该节点,那节点的个数就是行数了。获得单个节点的结构用的是SelectSingleNode,那这单个节点中子节点的个数n.ChildNodes.Length就是列数了。ns.Item(i).ChildNodes(j).text就是节点集ns中第i项的第j个子节点的值,我们要的内容也就取出来了。

那如果我不要取所有的列,只想取某几列,那怎么办,看代码

Private Sub OpenXml2()

Dim objDOM, n, ns, i, j, strh(), arr()

Cells.Clear

strh = Array("tdx", "tda", "tdb", "tdc", "tdk", "tdl", "tdy", "tdm", "tdn", "tdo", "tdp", "tdq", "tdu", "tdv", "td1", "new1", "new2")

Set objDOM = CreateObject("MSXML.DOMDocument")

objDOM.Load (ThisWorkbook.Path "\Rawdata.xml")

objDOM.async = False

'MsgBox objDOM.XML

Set ns = objDOM.SelectNodes("//extraction")

Set n = objDOM.SelectSingleNode("//extraction")

ReDim arr(1 To ns.Length, 1 To UBound(strh) + 1)

For i = 1 To ns.Length

For j = 1 To UBound(strh) + 1

On Error Resume Next

arr(i, j) = ns.Item(i - 1).GetElementsByTagname(strh(j - 1)).Item(0).Text

Next

Next

Set ns = Nothing

Set n = Nothing

Set objDOM = Nothing

Range("A1").Resize(UBound(arr), UBound(strh) + 1) = arr

End Sub

上面的代码就是取以"tdx", "tda", "tdb", "tdc", "tdk", "tdl", "tdy", "tdm", "tdn", "tdo", "tdp", "tdq", "tdu", "tdv", "td1", "new1", "new2"为标签的列,和前面不同的主要是这句ns.Item(i - 1).GetElementsByTagname(strh(j - 1)).Item(0).Text,用getelementsbytagname(节点名)取节点,ns.Item(i-1)是行节点的第n-1项,从这项中用GetElementsByTagname取出相应的列节点,一般来说到列了不会有多项了,所以我们直接用第1项(下标是0)的值来表示我们要的结果,之间的层层关系自己体会一下。

使用oracle解析xml

DECLARE

v_xmlstr VARCHAR2(1000);

v_xml XMLTYPE;

v_title VARCHAR2(50);

v_language VARCHAR2(50);

v_body VARCHAR2(50);

BEGIN

v_xmlstr := 'html

head

titleThis IS title./title

LANGUAGEJavaScript/LANGUAGE

/head

bodyI am BODY./body

/html';

v_xml := XMLTYPE(v_xmlstr); -- 生成XML

SELECT EXTRACTVALUE(VALUE(t),'/html/head/title')

,EXTRACTVALUE(VALUE(t),'/html/head/LANGUAGE')

,EXTRACTVALUE(VALUE(t),'/html/body')

INTO v_title ,v_language ,v_body

FROM TABLE(XMLSEQUENCE(EXTRACT(v_xml, '/html'))) t; -- 提取XML节点值

dbms_output.put_line(v_title);

dbms_output.put_line(v_language);

dbms_output.put_line(v_body);

END;

/

结果:

This IS title.

JavaScript

I am BODY.

(责任编辑:IT教学网)

更多