Skip to main content

Kutools for Office — 一套工具,五種功能。完成更多工作。

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

Author Siluvia Last modified

在之前的文章中,我們已經討論過在 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 助手:以智能執行為基礎,革新數據分析 生成程式碼 創建自訂公式 分析數據並生成圖表 調用 Kutools 增強函數
熱門功能查找、選取項目的背景色或標記重複值刪除空行合併列或單元格且不遺失數據四捨五入(免公式)...
高級 LOOKUP多條件 VLookup多值 VLookup多表查找模糊查找...
高級下拉列表快速創建下拉列表 依賴型下拉列表 多選下拉列表...
列管理器添加指定數量的列移動列切換隱藏列的顯示狀態比較區域及列...
精選功能網格聚焦 設計檢視 增強編輯欄 工作簿及工作表管理器 資源庫(快捷文本) 日期提取器 合併資料 加密/解密儲存格 按列表發送電子郵件 超級篩選 特殊篩選(篩選粗體/傾斜/刪除線...)...
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%,每日可幫您減少數百次鼠標點擊!

所有 Kutools 外掛,一次安裝

Kutools for Office 套裝整合了 Excel、Word、Outlook 和 PowerPoint 的外掛,外加 Office Tab Pro,非常適合需要跨 Office 應用程式協同作業的團隊。

Excel Word Outlook Tabs PowerPoint
  • 全合一套裝 — Excel、Word、Outlook及 PowerPoint 外掛 + Office Tab Pro
  • 一鍵安裝,一份授權 — 幾分鐘完成設置(支援 MSI)
  • 協同運作更順暢 — Office 應用間無縫提升生產力
  • 30 天全功能試用 — 無需註冊、無需信用卡
  • 最超值 — 一次購買,節省單獨外掛費用