国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 辦公 > Excel > 正文

Excel VBA如何根據姓名自動插入照片

2024-08-23 19:53:46
字體:
來源:轉載
供稿:網友

  一、前提條件

  在Excel的單元格中,已輸入人物的姓名,并且,在姓名的下面,留有空的單元格待插入相應的圖片。

  如下圖一樣。比如,B1是姓名,而B3則是要根據張三這個姓名,自動將張三這個人的照片插入到B3中。其它以此類推。

Excel VBA如何根據姓名自動插入照片 CUOxin.COM

  這得使用VBA來完成。

  同時,人物的照片所在的文件夾,和Excel工作薄,在相同的路徑,比如,下圖的位置。

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

電腦教程

  像這樣的問題需求,是具備一定規律的,因此,能使用VBA來完成。

  二、實現方法

  打開你的Excel,然后執行菜單操作:“工具”→“宏”→“宏”;彈出如下圖對話框。

  上圖中,宏名那里,輸入 AutoAddPic ,然后,點擊“創建”按鈕,彈出代碼輸入窗口,如下圖。

  代碼如上圖,請書寫完整,否則會發生異常。為方便大家的學習,下面將代碼寫為下文,以供參考:

  '自動插入圖片前,刪除所有圖片

  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 '選擇要插入圖片的單元格作為目標

  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

  書寫完代碼以后,點擊窗口中的保存,然后關閉代碼窗口,返回Excel窗口。

  接著,執行菜單操作:“工具”→“宏”→“宏”,彈出如下圖。

  選中上面所創建的宏名 AutoAddPic ,然后,點擊“執行”按鈕,這樣,Excel就會根據每個姓名找到所對應的照片,將照片插入到每一個人所對應的相應的單元格。

  三、知識擴展

  ThisWorkbook.ActiveSheet.UsedRange.Rows.Count 該行代碼的含義是,獲取工作表中的有效數據的最大行。

  If (ActiveSheet.Cells(i, 1).Value = "姓名")  判定第一列中的各行,其內容是否為“姓名”二字,是姓名就去找圖片來插入,否則就不找。

  MyPcName = ActiveSheet.Cells(i, 2).Value & ".gif" 獲取每個人的照片名稱,如 青山.gif

  ThisWorkbook.Path & "員工照片" & MyPcName 獲取每個人的照片所在的路徑,是完整的絕對路徑,而不是相對路徑。

  ActiveSheet.Cells(i + 2, 2).Select '選擇要插入圖片的單元格作為目標,即哪個單元格要插入圖片,就選中哪個

  ActiveSheet.Pictures.Insert(ThisWorkbook.Path & "員工照片" & MyPcName).Select '在選定的單元格中插入圖片

  If MyFile.FileExists(ThisWorkbook.Path & "員工照片" & MyPcName) = False Then 判斷員工照片是否存在


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 洛宁县| 勐海县| 黎城县| 鄂伦春自治旗| 饶平县| 宁晋县| 绍兴县| 漯河市| 富源县| 册亨县| 肃宁县| 安吉县| 罗城| 塔城市| 无棣县| 醴陵市| 梁平县| 南昌县| 龙海市| 丰镇市| 大化| 祁东县| 漳州市| 连州市| 康平县| 繁昌县| 陆良县| 延安市| 双城市| 平和县| 方正县| 安达市| 沛县| 凌源市| 洪泽县| 文成县| 枣强县| 疏勒县| 大埔县| 浦东新区| 日喀则市|