Skip to main content

在 Excel 中使用 Vlookup 時,如何複製查找單元格的源格式?

Author: Siluvia Last Modified: 2025-05-12

在之前的文章中,我們已經討論過在 Excel 中進行 vlookup 查找值時保留背景色的方法。本文將介紹一種在 Excel 中執行 Vlookup 時複製結果單元格所有格式的方法。請按照以下步驟操作。

使用自定義函數在 Excel 中進行 Vlookup 時複製源格式


使用自定義函數在 Excel 中進行 Vlookup 時複製源格式

假設您有一個如下截圖所示的表格。現在,您需要檢查指定值(在 E 列中)是否在 A 列中,並返回 C 列中帶有格式的對應值。請按照以下步驟操作以實現此目的。

vlookup keep cell formatting

1. 在包含要查找值的工作表中,右鍵單擊工作表標籤,然後從上下文選單中選擇「檢視程式碼」。請參見截圖:

right-click the sheet tab and select View Code

2. 在打開的 Microsoft Visual Basic for Applications 視窗中,請將以下 VBA 程式碼複製到程式碼視窗中。

VBA 程式碼 1:Vlookup 並返回帶有格式的值

Sub Worksheet_Change(ByVal Target As Range)
'Update by Extendoffice 20211203
    Dim I As Long
    Dim xKeys As Long
    Dim xDicStr As String
    On Error Resume Next
    Application.ScreenUpdating = False
    Application.CutCopyMode = False
    xKeys = UBound(xDic.Keys)
    If xKeys >= 0 Then
        For I = 0 To UBound(xDic.Keys)
            xDicStr = xDic.Items(I)
            If xDicStr <> "" Then
                Set xRg = Application.Range(xDicStr)
                xRg.Copy
                Range(xDic.Keys(I)).PasteSpecial xlPasteFormats
            Else
                Range(xDic.Keys(I)).Interior.Color = xlNone
            End If
        Next
        Set xDic = Nothing
    End If
    Application.ScreenUpdating = True
    Application.CutCopyMode = True
End Sub

3. 然後點擊 插入 > 模組,並將以下 VBA 程式碼 2 複製到模組視窗中。

VBA 程式碼 2:Vlookup 並返回帶有格式的值

Public xDic As New Dictionary
'Update by Extendoffice 20211203
Function LookupKeepFormat(ByRef FndValue, ByRef LookupRng As Range, ByRef xCol As Long)
    Dim xFindCell As Range
    On Error Resume Next
    Application.ScreenUpdating = False
    Set xFindCell = LookupRng.Find(FndValue, , xlValues, xlWhole)
    If xFindCell Is Nothing Then
        LookupKeepFormat = " "
        xDic.Add Application.Caller.Address, " "
    Else
        LookupKeepFormat = xFindCell.Offset(0, xCol - 1).Value
        xDic.Add Application.Caller.Address, xFindCell.Offset(0, xCol - 1).Address(External:=True)
    End If
    Application.ScreenUpdating = True
End Function

4. 點擊 工具 > 參考資料。然後在「參考資料 – VBAProject」對話框中勾選 Microsoft Script Runtime 選項。請參見截圖:

Tools > References, then, check the Microsoft Script Runtime box

5. 按下 Alt + Q 鍵退出 Microsoft Visual Basic for Applications 視窗。

6. 選擇查找值旁邊的一個空白單元格,然後在 編輯欄(F) 中輸入公式 =LookupKeepFormat(E2,$A$1:$C$8,3),然後按下 Enter 鍵。

apply a formula to get the first result

注意:在該公式中,E2 包含要查找的值,$A$1:$C$8 是表格區域,數字 3 表示要返回的對應值位於表格的第三列。請根據需要更改它們。

7. 繼續選擇第一個結果單元格,然後向下拖動填充柄以獲取所有帶有其格式的結果,如下截圖所示。

drag and fill the formula to other cells

a screenshot of kutools for excel ai

使用 Kutools AI 解鎖 Excel 的魔法

  • 智能執行:執行單元格操作、分析數據並創建圖表——所有這些都由簡單的指令驅動。
  • 自訂公式:生成量身定制的公式,簡化您的工作流程。
  • VBA 編碼:輕鬆編寫和實現 VBA 代碼。
  • 公式解釋:輕鬆理解複雜的公式。
  • 文本翻譯:打破電子表格中的語言障礙。
通過人工智能工具增強您的 Excel 能力。立即下載,體驗前所未有的效率!

相關文章:

最佳辦公效率工具

🤖 Kutools AI 助手:基於智能執行方式革新數據分析:智能執行   |  生成代碼  |  創建自訂公式  |  分析數據並生成圖表  |  調用 Kutools 函數
熱門功能查找、標記重複值或識別重複項   |  刪除空行   |  合併列或單元格而不丟失數據   |   四捨五入無需公式 ...
高級 LOOKUP多條件 VLookup    多值 VLookup  |   多表查找   |   模糊查找 ....
高級下拉列表快速創建下拉列表   |  依賴下拉列表   |  多選下拉列表 ....
列管理器添加特定數量的列  |  移動列  |  切換隱藏列的可見狀態  |  比較區域和列 ...
特色功能網格聚焦   |  設計檢視   |   增強編輯欄    工作簿與工作表管理器   |  資源庫(自動文本)   |  日期提取器   |  合併資料   |  加密/解密儲存格    按列表發送電子郵件   |  超級篩選   |   特殊篩選(篩選粗體/斜體/刪除線...) ...
頂級 15 種工具集12 個文本工具添加文本刪除特定字符、...)   |   50+ 圖表 類型甘特圖、...)   |   40+ 實用 公式基於生日計算年齡、...)   |   19 個插入工具插入QR碼根據路徑插入圖片、...)   |   12 個轉換工具金額轉大寫匯率轉換、...)   |   7 個合併與分割工具高級合併行分割儲存格、...)   |   ... 還有更多

使用 Kutools for Excel 提升您的 Excel 技巧,體驗前所未有的高效。 Kutools for Excel 提供超過 300 種高級功能來提高生產力並節省時間。  點擊這裡獲取您最需要的功能...


Office Tab 將標籤式界面帶到 Office,讓您的工作更加輕鬆

  • 在 Word、Excel、PowerPoint、Publisher、Access、Visio 和 Project 中啟用標籤式編輯和閱讀。
  • 在同一窗口的新標籤中打開和創建多個文檔,而不是在新窗口中。
  • 將您的生產力提高 50%,每天為您減少數百次鼠標點擊!