91网首页-91网页版-91网在线观看-91网站免费观看-91网站永久视频-91网站在线播放

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

VB讀寫XML文檔

admin
2012年7月9日 0:37 本文熱度 4034

   在VB中我們可以使用XML解釋器來對XML文件進行各種操作.XML解釋器被封裝在一個名字叫做msxml.dll的動態(tài)連接庫文件中,它是一個COM對象.因此所有可以兼容ActiveX的環(huán)境中都可以使用該方法操作XML文檔.

我們用一個實例來說明.

首先,我們建立一個名字為test.xml的xml文件.內(nèi)容如下:

<作者信息>

<網(wǎng)名>古鐵神刀</網(wǎng)名>

<性別>男</性別>

<手機>13584517846</手機>

<電話>0531-82296272</電話>

<QQ>362880403</QQ>

<個人主頁>http://www.xyxtl.cn</個人主頁>

</作者信息>

    新建一個標(biāo)準(zhǔn)EXE工程。選擇"工程" - "引用",選取"Microsoft XML V2.0"或更高版本.這樣我們就可以使用xml解釋器了.

    接下來在form中添加控件.

切換到代碼視圖,添加如下代碼:

Option Explicit

Private p_AppPath As String          '當(dāng)前目錄路徑

Private Sub Form_Load()

  '得到當(dāng)前目錄

  p_AppPath = App.Path

  If Right(p_AppPath, 1) <> "/" And Right(p_AppPath, 1) <> "" Then

     p_AppPath = p_AppPath & "/"

  End If

End Sub

分別雙擊載入、保存、退出系統(tǒng),添加代碼:

Private Sub cmdLoad_Click()

    '載入文件內(nèi)容

    loadValues

End Sub

Private Sub cmdSave_Click()

    '保存當(dāng)前內(nèi)容

    saveValues

End Sub

Private Sub cmdQuit_Click()

  Unload Me

End Sub

現(xiàn)在我們編寫過程實現(xiàn)文件的讀入和寫出:

Private Sub loadValues()

  Dim xml_document As DOMDocument

  Dim values_node As IXMLDOMNode

  '載入文件

  Set xml_document = New DOMDocument

  MsgBox p_AppPath & "test.xml"

  xml_document.Load p_AppPath & "test.xml"

  If xml_document.documentElement Is Nothing Then

    Exit Sub

  End If

  '尋找節(jié)點

  Set values_node = xml_document.selectSingleNode("作者信息")

  '讀取各個節(jié)點的值

  txtName.Text = GetNodeValue(values_node, "網(wǎng)名", "???")

  txtSex.Text = GetNodeValue(values_node, "性別", "???")

  txtHand.Text = GetNodeValue(values_node, "手機", "???")

  txtTel.Text = GetNodeValue(values_node, "電話", "???")

  txtQQ.Text = GetNodeValue(values_node, "QQ", "???")

  txtPage.Text = GetNodeValue(values_node, "個人主頁", "???")

End Sub

Private Function GetNodeValue(ByVal start_at_node As IXMLDOMNode, ByVal node_name As String, Optional ByVal default_value As String = "") As String

  Dim value_node As IXMLDOMNode

  Set value_node = start_at_node.selectSingleNode(".//" & node_name)

  If value_node Is Nothing Then

    GetNodeValue = default_value

  Else

    GetNodeValue = value_node.Text

  End If

End Function

'保存現(xiàn)有的值

Private Sub SaveValues()

  Dim xml_document As DOMDocument

  Dim values_node As IXMLDOMNode

  '建立XML文件

  Set xml_document = New DOMDocument

  Set values_node = xml_document.createElement("作者信息")

  xml_document.appendChild values_node

  CreateNode values_node, "網(wǎng)名", txtName.Text

  CreateNode values_node, "性別", txtSex.Text

  CreateNode values_node, "手機", txtHand.Text

  CreateNode values_node, "電話", txtTel.Text

  CreateNode values_node, "QQ", txtQQ.Text

  CreateNode values_node, "個人主頁", txtPage.Text

  '保存XML文件

  xml_document.save p_AppPath & "test.xml"

End Sub

Private Sub CreateNode(ByVal parent As IXMLDOMNode, ByVal node_name As String, ByVal node_value As String)

  Dim new_node As IXMLDOMNode

  Set new_node = parent.ownerDocument.createElement(node_name)

  new_node.Text = node_value

  parent.appendChild new_node

End Sub

最后運行程序,看一下效果


該文章在 2012/7/9 0:43:28 編輯過

全部評論1

admin
2012年7月9日 0:40

vb 讀取 XML 文件 內(nèi)容

 

在form上添加button 和 text(設(shè)置multiLine=true和垂直滾動條)

Private Sub Command1_Click()
    Dim xmldoc As DOMDocument
    Dim nodes As IXMLDOMNode
    Dim cnodes As IXMLDOMNode

    Set xmldoc = New DOMDocument
    xmldoc.Load App.Path + "\test.xml"
    If xmldoc.documentElement Is Nothing Then
        Exit Sub
    End If
   
  
    Set nodes = xmldoc.documentElement.childNodes(0) '第一個節(jié)點
   
    Text1.Text = ""
    For i = 0 To nodes.childNodes.length - 1  ''第一個節(jié)點的下一層節(jié)點 (2層)
        Set cnodes = nodes.childNodes.Item(i)
        For Each pp In cnodes.childNodes  '3層
            If LCase(pp.Attributes.getNamedItem("name").nodeValue) = "name" Then  '節(jié)點名為name
                Text1.Text = Text1.Text + CStr(pp.Text) + ","
            End If
           
            If LCase(pp.Attributes.getNamedItem("name").nodeValue) = "fullname" Then
                Text1.Text = Text1.Text + CStr(pp.Text) + ","
            End If
           
            If LCase(pp.Attributes.getNamedItem("name").nodeValue) = "description" Then
                Text1.Text = Text1.Text + CStr(pp.Text) + vbCrLf
            End If
            Text1.Refresh
        Next
 
    Next

End Sub


該評論在 2012/7/9 0:41:09 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運作、調(diào)度、堆場、車隊、財務(wù)費用、相關(guān)報表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點,圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點晴WMS倉儲管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務(wù)都免費,不限功能、不限時間、不限用戶的免費OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 另类图区亚 | 国产亚洲中文 | 尤物网红麻酥酥 | 精品日韩欧美在 | 国产精品码一区 | 成人伊人222 | 九九精品视频亚州 | 成人午夜婬片A | 国内一点不卡在 | 日韩欧群 | 国产女同精品9 | 日韩一级中文字幕 | 欧美综合影院 | 国产专区日韩专区 | www.成人导航 | 日本福利 | 日韩一级一欧美一级 | 欧美日韩一区四区 | 中文字幕在 | 日本大片免费一级 | 福利在线视频导航 | 日韩专区在线观 | 日本一区二区电影 | 国产精品第32页 | 福利一区二区 | 国产主播福利大全 | 欧美日韩人兽 | 欧美午夜高清在线 | 国产精品高朝1 | 国产日本免费乱伦 | 97在线视频免费 | 国产热の有码 | 区三区日韩精品 | 老司机精品导航 | 国产大片线上 | 国产精品国产精品馆 | 国产极品 | 九九九五月天 | 国产凸凹视频 | www日本色清| 精品理论片 |