狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

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

VB讀寫XML文檔

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

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

我們用一個(gè)實(shí)例來說明.

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

<作者信息>

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

<性別>男</性別>

<手機(jī)>13584517846</手機(jī)>

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

<QQ>362880403</QQ>

<個(gè)人主頁(yè)>http://www.xyxtl.cn</個(gè)人主頁(yè)>

</作者信息>

    新建一個(gè)標(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)在我們編寫過程實(shí)現(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é)點(diǎn)

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

  '讀取各個(gè)節(jié)點(diǎn)的值

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

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

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

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

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

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

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, "手機(jī)", txtHand.Text

  CreateNode values_node, "電話", txtTel.Text

  CreateNode values_node, "QQ", txtQQ.Text

  CreateNode values_node, "個(gè)人主頁(yè)", 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

最后運(yùn)行程序,看一下效果


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

全部評(píng)論1

admin
2012年7月9日 0:40

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

 

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

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) '第一個(gè)節(jié)點(diǎn)
   
    Text1.Text = ""
    For i = 0 To nodes.childNodes.length - 1  ''第一個(gè)節(jié)點(diǎn)的下一層節(jié)點(diǎn) (2層)
        Set cnodes = nodes.childNodes.Item(i)
        For Each pp In cnodes.childNodes  '3層
            If LCase(pp.Attributes.getNamedItem("name").nodeValue) = "name" Then  '節(jié)點(diǎn)名為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


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