在 Excel 中使用 Vlookup 時,如何複製查找單元格的源格式?
在之前的文章中,我們已經討論過在 Excel 中進行 vlookup 查找值時保留背景色的方法。本文將介紹一種在 Excel 中執行 Vlookup 時複製結果單元格所有格式的方法。請按照以下步驟操作。
使用自定義函數在 Excel 中進行 Vlookup 時複製源格式
使用自定義函數在 Excel 中進行 Vlookup 時複製源格式
假設您有一個如下截圖所示的表格。現在,您需要檢查指定值(在 E 列中)是否在 A 列中,並返回 C 列中帶有格式的對應值。請按照以下步驟操作以實現此目的。
1. 在包含要查找值的工作表中,右鍵單擊工作表標籤,然後從上下文選單中選擇「檢視程式碼」。請參見截圖:
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 選項。請參見截圖:
5. 按下 Alt + Q 鍵退出 Microsoft Visual Basic for Applications 視窗。
6. 選擇查找值旁邊的一個空白單元格,然後在 編輯欄(F) 中輸入公式 =LookupKeepFormat(E2,$A$1:$C$8,3),然後按下 Enter 鍵。
注意:在該公式中,E2 包含要查找的值,$A$1:$C$8 是表格區域,數字 3 表示要返回的對應值位於表格的第三列。請根據需要更改它們。
7. 繼續選擇第一個結果單元格,然後向下拖動填充柄以獲取所有帶有其格式的結果,如下截圖所示。

使用 Kutools AI 解鎖 Excel 的魔法
- 智能執行:執行單元格操作、分析數據並創建圖表——所有這些都由簡單的指令驅動。
- 自訂公式:生成量身定制的公式,簡化您的工作流程。
- VBA 編碼:輕鬆編寫和實現 VBA 代碼。
- 公式解釋:輕鬆理解複雜的公式。
- 文本翻譯:打破電子表格中的語言障礙。
相關文章:
- 如何在 Excel 中進行 vlookup 並返回查找值及其背景色?
- 如何在 Excel 中進行 vlookup 並返回日期格式而不是數字?
- 如何在 Excel 中使用 vlookup 和求和功能?
- 如何在 Excel 中進行 vlookup 並返回相鄰或下一單元格中的值?
- 如何在 Excel 中進行 vlookup 並返回真/假 或 是/否 的值?
最佳 Office 辦公效率工具
🤖 | Kutools AI Aide:徹底革新數據分析,基於智能執行|生成程式碼|創建自訂公式|分析數據並生成圖表|調用 Kutools Functions… |
熱門功能:查找、選取項目的背景色或標記重複值 | 刪除空行 | 合併列或單元格且不丟失資料 | 四捨五入... | |
高級 LOOKUP:多條件查找|多值查找|多表查找|模糊查找... | |
高級下拉列表:快速創建下拉列表 | 關聯下拉列表 | 多選下拉列表 ... | |
列管理器: 添加指定數量的列 | 移動列 | 切換隱藏列的可見狀態 | 區域與列比較 ... | |
精選功能:網格聚焦 | 設計檢視 | 增強編輯欄 | 工作簿及工作表管理器 | 資源庫 (自動文本) | 日期提取器 | 合併資料 | 加密/解密儲存格 | 按清單發送電子郵件 | 超級篩選 | 特殊篩選(篩選粗體/傾斜/刪除線 ...)... | |
前15 大工具集:12 款文本工具(添加文本,刪除特定字符,...)|50+ 種圖表 類型(甘特圖,...)|40+ 實用 公式(基於生日計算年齡,...)|19 款插入工具(插入QR码,按路徑插入圖片,...)|12 款轉換工具(金額轉大寫,匯率轉換,...)|7 款合併和分割工具(高級合併行,分割儲存格,...)| ...以及更多 |
利用 Kutools for Excel 大幅提升你的 Excel 技能,感受前所未有的高效體驗。 Kutools for Excel 提供超過300 項高級功能,助你提升效率並保存時間。 點此查看你最需要的功能...
Office Tab 為 Office 帶來標籤式介面,讓你的工作更加輕鬆
- 啟用 Word、Excel、PowerPoint 的標籤式編輯和閱讀功能
- 在同一個視窗的標籤中打開和創建多個文件,而不是在新窗口中分開開啟。
- 可提升你50% 的工作效率,每天為你大量減少滑鼠點擊次數!