在Excel中如何使用VBA根據(jù)姓名自動(dòng)插入照片

一、前提條件
在Excel的單元格中,已輸入人物的姓名,并且,在姓名的下面,留有空的單元格待插入相應(yīng)的圖片。
如下圖一樣。比如,B1是姓名,而B3則是要根據(jù)張三這個(gè)姓名,自動(dòng)將張三這個(gè)人的照片插入到B3中。其它以此類推。

這得使用VBA來完成。
同時(shí),人物的照片所在的文件夾,和Excel工作薄,在相同的路徑,比如,下圖的位置。

另外,每個(gè)員工的照片的名稱,都是按照員工的姓名來命名的,如下圖。

像這樣的問題需求,是具備一定規(guī)律的,因此,能使用VBA來完成。
二、實(shí)現(xiàn)方法
打開你的Excel,然后執(zhí)行菜單操作:“工具”→“宏”→“宏”;彈出如下圖對(duì)話框。

上圖中,宏名那里,輸入 AutoAddPic ,然后,點(diǎn)擊“創(chuàng)建”按鈕,彈出代碼輸入窗口,如下圖。

代碼如上圖,請(qǐng)書寫完整,否則會(huì)發(fā)生異常。為方便大家的學(xué)習(xí),下面將代碼寫為下文,以供參考:
'自動(dòng)插入圖片前,刪除所有圖片
For Each Shp In ActiveSheet.Shapes
If Shp.Type = msoPicture Then Shp.Delete
Next
Dim MyPcName As String
For i = 1 To ThisWorkbook.ActiveSheet.UsedRange.Rows.Count
If (ActiveSheet.Cells(i, 1).Value = "姓名") Then
MyPcName = ActiveSheet.Cells(i, 2).Value & ".gif"
'MsgBox "圖片的完整路徑是" & ThisWorkbook.Path & "員工照片" & MyPcName
ActiveSheet.Cells(i + 2, 2).Select '選擇要插入圖片的單元格作為目標(biāo)
Dim MyFile As Object
Set MyFile = CreateObject("Scripting.FileSystemObject")
If MyFile.FileExists(ThisWorkbook.Path & "員工照片" & MyPcName) = False Then
MsgBox ThisWorkbook.Path & "員工照片" & MyPcName & "圖片不存在"
Else
'在選定的單元格中插入圖片
ActiveSheet.Pictures.Insert(ThisWorkbook.Path & "員工照片" & MyPcName).Select
End If
End If
Next i
書寫完代碼以后,點(diǎn)擊窗口中的保存,然后關(guān)閉代碼窗口,返回Excel窗口。
接著,執(zhí)行菜單操作:“工具”→“宏”→“宏”,彈出如下圖。

選中上面所創(chuàng)建的宏名 AutoAddPic ,然后,點(diǎn)擊“執(zhí)行”按鈕,這樣,Excel就會(huì)根據(jù)每個(gè)姓名找到所對(duì)應(yīng)的照片,將照片插入到每一個(gè)人所對(duì)應(yīng)的相應(yīng)的單元格。
三、知識(shí)擴(kuò)展
ThisWorkbook.ActiveSheet.UsedRange.Rows.Count 該行代碼的含義是,獲取工作表中的有效數(shù)據(jù)的最大行。
If (ActiveSheet.Cells(i, 1).Value = "姓名") 判定第一列中的各行,其內(nèi)容是否為“姓名”二字,是姓名就去找圖片來插入,否則就不找。
MyPcName = ActiveSheet.Cells(i, 2).Value & ".gif" 獲取每個(gè)人的照片名稱,如 青山.gif
ThisWorkbook.Path & "員工照片" & MyPcName 獲取每個(gè)人的照片所在的路徑,是完整的絕對(duì)路徑,而不是相對(duì)路徑。
ActiveSheet.Cells(i + 2, 2).Select '選擇要插入圖片的單元格作為目標(biāo),即哪個(gè)單元格要插入圖片,就選中哪個(gè)
ActiveSheet.Pictures.Insert(ThisWorkbook.Path & "員工照片" & MyPcName).Select '在選定的單元格中插入圖片
If MyFile.FileExists(ThisWorkbook.Path & "員工照片" & MyPcName) = False Then 判斷員工照片是否存在
相關(guān)文章
陽歷/農(nóng)歷轉(zhuǎn)換對(duì)照表怎么做? Excel制作日歷表/萬年歷的最終版
想要制作陽歷/農(nóng)歷轉(zhuǎn)換對(duì)照表,,通過這個(gè)對(duì)照表,你只需知道陽歷日期,就可以快速準(zhǔn)確的找到對(duì)應(yīng)的農(nóng)歷日期,下面我們就來看看詳細(xì)制作方法2025-04-10三分鐘就搞定! Excel快速制作一個(gè)日歷表/萬年歷的技巧
工作上需要制作一個(gè)日歷表/萬年歷,該怎么制作呢?我們需要使用三個(gè)excel函數(shù)來實(shí)現(xiàn),詳細(xì)請(qǐng)看下文介紹2025-04-10這個(gè)函數(shù)公式簡(jiǎn)直太強(qiáng)了! excel按權(quán)重求和計(jì)算的技巧
Excel中有一個(gè)功能非常強(qiáng)大的函數(shù),它就是SUMPRODUCT函數(shù),既能求和、計(jì)數(shù)、權(quán)重計(jì)算,還能排名等,今天我們就來看看Excel根據(jù)權(quán)重求和的技巧2025-04-10tocol函數(shù)哪個(gè)版本能用? excel中tocol函數(shù)的兩種高級(jí)用法
TOCOL函數(shù)公式非常強(qiáng)大,值得一學(xué),從字面意義可以理解出來,它是將數(shù)據(jù)轉(zhuǎn)換成一列的,今天分享TOCOL函數(shù)的2種高級(jí)用法2025-04-10Excel隱藏行和折疊行有什么不同? 隱藏行和折疊使用方法和區(qū)別介紹
excel表格進(jìn)行操作的時(shí)候,發(fā)現(xiàn)有隱藏和和折疊行,看上去效果一樣,都隱藏了,但是兩者是有很大區(qū)別的,詳細(xì)請(qǐng)看下文介紹2025-03-21Excel工齡計(jì)算不再愁! Excel隱藏函數(shù)DATEDIF輕松計(jì)算精確到天級(jí)的工齡
在日常工作中,我們經(jīng)常需要計(jì)算員工的工齡,以便進(jìn)行人事管理、薪資調(diào)整等工作,本文將詳細(xì)介紹如何在Excel表格中計(jì)算工齡,并提供多種實(shí)用方法供您選擇2025-03-13快速提高工作效率! Excel高手的8個(gè)技巧勸你學(xué)學(xué)
Excel數(shù)據(jù)處理遇到的問題,99%都是由于奇葩的數(shù)據(jù)格式造成的,今天跟大家整理了幾個(gè)Excel表格構(gòu)建的規(guī)則,先不要問為什么,照著做就對(duì)了2025-03-06Excel透視表1月到12月不能排序怎么辦? 數(shù)據(jù)透視表日期無法排序解決方法
如圖對(duì)數(shù)據(jù)透視表日期進(jìn)行升序排序后,仍不是我們想要的結(jié)果,有可能月份是文本,不能排列,下面我們就來看看詳細(xì)解決辦法2025-03-06財(cái)務(wù)審計(jì)必會(huì)! 2分鐘搞定用excel做賬齡劃分的技巧
首先咱們得明確一下賬齡的概念,簡(jiǎn)單來說,賬齡就是某個(gè)賬戶的余額從產(chǎn)生到現(xiàn)在的時(shí)間長(zhǎng)度,比如,一年以內(nèi)的賬齡就是那些在過去一年內(nèi)產(chǎn)生的債權(quán)或債務(wù),下面我們就來看看2025-03-06實(shí)現(xiàn)辦公自動(dòng)化! DeepSeek搭配Excel制作自定義按鈕的技巧
DeepSeek生成想要的代碼很方便,如果將生成的代碼放到excel中作為vba代碼使用,豈不是能實(shí)現(xiàn)辦公自動(dòng)化?下面我們就來看看實(shí)現(xiàn)方法2025-03-05