Skip to main content

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

Author: Siluvia Last Modified: 2025-08-06

在之前的文章中,我們已經討論過在 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 能力。立即下載,體驗前所未有的效率!

相關文章:

最佳 Office 辦公效率工具

🤖 Kutools AI Aide:徹底革新數據分析,基於智能執行|生成程式碼|創建自訂公式|分析數據並生成圖表|調用 Kutools Functions
熱門功能查找、選取項目的背景色或標記重複值 | 刪除空行 | 合併列或單元格且不丟失資料 | 四捨五入...
高級 LOOKUP多條件查找|多值查找|多表查找|模糊查找...
高級下拉列表快速創建下拉列表 | 關聯下拉列表 | 多選下拉列表 ...
列管理器添加指定數量的列 | 移動列 | 切換隱藏列的可見狀態 | 區域與列比較 ...
精選功能網格聚焦 | 設計檢視 | 增強編輯欄 | 工作簿及工作表管理器 | 資源庫 (自動文本) | 日期提取器 | 合併資料 | 加密/解密儲存格 | 按清單發送電子郵件 | 超級篩選 | 特殊篩選(篩選粗體/傾斜/刪除線 ...)...
前15 大工具集12 款文本工具添加文本刪除特定字符,...)|50+ 種圖表 類型甘特圖,...)|40+ 實用 公式基於生日計算年齡,...)|19 款插入工具插入QR码按路徑插入圖片,...)|12 款轉換工具金額轉大寫匯率轉換,...)|7 款合併和分割工具高級合併行分割儲存格,...)| ...以及更多
使用 Kutools 支援你的語言——支援英語、西班牙語、德語、法語、中文及40 多種語言!

利用 Kutools for Excel 大幅提升你的 Excel 技能,感受前所未有的高效體驗。 Kutools for Excel 提供超過300 項高級功能,助你提升效率並保存時間。 點此查看你最需要的功能...


Office Tab 為 Office 帶來標籤式介面,讓你的工作更加輕鬆

  • 啟用 Word、Excel、PowerPoint 的標籤式編輯和閱讀功能
  • 在同一個視窗的標籤中打開和創建多個文件,而不是在新窗口中分開開啟。
  • 可提升你50% 的工作效率,每天為你大量減少滑鼠點擊次數!