首先,由于缺乏信息,我将假设一个场景并尝试实现您所需要的。您可能需要稍微更改代码才能满足您的需求,但这为您的工作奠定了基础。
由于您的 XML 源不包含其他数据,因此包含电子邮件地址的表不会根据您的需要向表的其余部分添加行。我的建议是您使用 vba 代码来为您完成这项工作。
假设您有以下 xml 文件:
<?xml version="1.0" encoding="UTF-8"?>
<Email>
    <address>teste@teste.com</address>
    <address>teste1@teste.com</address>
    <address>teste2@teste.com</address>
    <address>teste3@teste.com</address>
    <address>teste4@teste.com</address>
    <address>teste6@teste.com</address>
</Email>
使用以下代码将在工作表上生成一个表格:
Const xmlFileUrl As String = "c:\filePath\note.xml"
Sub ClearXmlMaps()
    Dim existingXmlMap As XmlMap
    For Each existingXmlMap In ActiveWorkbook.XmlMaps
       existingXmlMap.Delete
    Next existingXmlMap
End Sub
Sub CreateMailList()
    Dim xmlTable As XmlMap
    ClearXmlMaps
    Application.WindowState = xlNormal
    ActiveWorkbook.XmlImport URL:=xmlFileUrl, ImportMap:=Nothing, Overwrite:=True, Destination:=Range("$A$1")
    Set xmlTable = ActiveWorkbook.XmlMaps(1)
    xmlTable.Name = "EmailList"
End Sub
该代码生成了下表的红色方块部分:

我添加了一个名为“名称”的新列。现在假设我想要刷新 XML 提要而不清除列名称上的所有信息。为此,我将使用辅助表(这里的主表是“数据”,辅助表是“Aux”表)来复制所有数据,刷新提要,最后使用最后的状态重新填充我的表VLOOKUP命令,如下:
Sub RefreshEmailList()
    Dim existingXmlMap As XmlMap
    Dim dataSheet As Worksheet
    Dim auxSheet As Worksheet
    Set dataSheet = ThisWorkbook.Worksheets("Data")
    Set auxSheet = ThisWorkbook.Worksheets("Aux")
    dataSheet.Cells.Copy auxSheet.Cells(1, 1)
    auxSheet.Range(auxSheet.Cells(1, 1), auxSheet.Cells(auxSheet.Cells(auxSheet.Rows.Count, 1).End(xlUp).Row, auxSheet.Cells(1, auxSheet.Columns.Count).End(xlToLeft).Column)).Value = auxSheet.Range(auxSheet.Cells(1, 1), auxSheet.Cells(auxSheet.Cells(auxSheet.Rows.Count, 1).End(xlUp).Row, auxSheet.Cells(1, auxSheet.Columns.Count).End(xlToLeft).Column)).Value
    dataSheet.Range(dataSheet.Cells(2, 2), dataSheet.Cells(dataSheet.Cells(dataSheet.Rows.Count, 1).End(xlUp).Row, dataSheet.Cells(1, dataSheet.Columns.Count).End(xlToLeft).Column)).Clear
    For Each existingXmlMap In ThisWorkbook.XmlMaps
        If existingXmlMap.Name = "EmailList" Then
            ActiveWorkbook.XmlMaps("EmailList").DataBinding.Refresh
        End If
    Next existingXmlMap
    dataSheet.Range(dataSheet.Cells(2, 2), dataSheet.Cells(dataSheet.Cells(dataSheet.Rows.Count, 1).End(xlUp).Row, dataSheet.Cells(1, dataSheet.Columns.Count).End(xlToLeft).Column)).FormulaR1C1 = "=IFERROR(IF(VLOOKUP([@address],Aux!C1:C,COLUMN(),FALSE) = 0 , """", VLOOKUP([@address],Aux!C1:C,COLUMN(),FALSE)), """")"
    dataSheet.Range(dataSheet.Cells(2, 2), dataSheet.Cells(dataSheet.Cells(dataSheet.Rows.Count, 1).End(xlUp).Row, dataSheet.Cells(1, dataSheet.Columns.Count).End(xlToLeft).Column)).Value = dataSheet.Range(dataSheet.Cells(2, 2), dataSheet.Cells(dataSheet.Cells(dataSheet.Rows.Count, 1).End(xlUp).Row, dataSheet.Cells(1, dataSheet.Columns.Count).End(xlToLeft).Column)).Value
End Sub
如果将 xml 文件更改为以下内容:
<?xml version="1.0" encoding="UTF-8"?>
<Email>
    <address>teste@teste.com</address>
    <address>teste1@teste.com</address>
    <address>teste2@teste.com</address>
    <address>teste3@teste.com</address>
    <address>teste4@teste.com</address>
    <address>teste5@teste.com</address>
    <address>teste6@teste.com</address>
</Email>
然后运行 RefreshEmailList() 子例程,您将得到以下结果:

上面的解决方案适用于添加或删除行,但您应该注意两件事:
| 归档时间: | 
 | 
| 查看次数: | 1078 次 | 
| 最近记录: |