欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

VB讀寫XML文檔

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

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

我們用一個實例來說明.

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

<作者信息>

<網名>古鐵神刀</網名>

<性別>男</性別>

<手機>13584517846</手機>

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

<QQ>362880403</QQ>

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

</作者信息>

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

    接下來在form中添加控件.

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

Option Explicit

Private p_AppPath As String          '當前目錄路徑

Private Sub Form_Load()

  '得到當前目錄

  p_AppPath = App.Path

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

     p_AppPath = p_AppPath & "/"

  End If

End Sub

分別雙擊載入、保存、退出系統,添加代碼:

Private Sub cmdLoad_Click()

    '載入文件內容

    loadValues

End Sub

Private Sub cmdSave_Click()

    '保存當前內容

    saveValues

End Sub

Private Sub cmdQuit_Click()

  Unload Me

End Sub

現在我們編寫過程實現文件的讀入和寫出:

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

  '尋找節點

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

  '讀取各個節點的值

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

  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

'保存現有的值

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, "網名", 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 文件 內容

 

在form上添加button 和 text(設置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) '第一個節點
   
    Text1.Text = ""
    For i = 0 To nodes.childNodes.length - 1  ''第一個節點的下一層節點 (2層)
        Set cnodes = nodes.childNodes.Item(i)
        For Each pp In cnodes.childNodes  '3層
            If LCase(pp.Attributes.getNamedItem("name").nodeValue) = "name" Then  '節點名為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 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved