這篇文章為大家帶來了關於excel的相關知識,其中主要整理了怎麼按名稱查詢圖片的相關問題,包括瞭如何將圖片從一張工作表插入到另外一張工作表、根據資料表的A列的圖片名稱,將照片表的照片批量插入到資料表的B列中等等內容,下面一起來看一下,希望對大家有幫助。
相關學習推薦:excel教學
#如何將圖片從一張工作表插入到另外一張工作表呢?舉個例子。
如下圖:
一份工作簿有兩張工作表。
存放照片的工作表名稱為【照片】,需要插入圖片的工作表名稱為【資料】。
現在需要根據【資料】表的A列的圖片名稱,將【照片】表的照片批次插入到【資料】表的B列中去…
範例動畫如下:
……
實現這樣的功能,其實3句程式碼就夠了。
程式碼如下:
Sub InsertPicFromSheet() Dim rngData As Range, rngPicName As Range For Each rngData In Range("a2", Cells(Rows.Count, 1).End(3)) Set rngPicName = Sheets("照片").Cells.Find(rngData.Value, , , xlWhole) '使用Find方法在照片表完整匹配姓名 If Not rngPicName Is Nothing Then rngPicName.Offset(0, 1).Copy rngData.Offset(0, 1) '如果有找到对应的姓名,则将照片复制粘贴到目标位置 Next End Sub
不過…
以上程式碼最大的問題在於,沒有刪除資料表原本就有舊圖片,如果重複執行程序,會造成圖片累積,為了解決這個問題,我們需要再加上兩句程式碼。
程式碼修改如下:
Sub InsertPicFromSheet() Dim shp As Shape, rngData As Range, rngPicName As Range For Each shp In ActiveSheet.Shapes '删除活动工作表原有照片 If shp.Type = 13 Then shp.Delete Next For Each rngData In Range("a2", Cells(Rows.Count, 1).End(3)) Set rngPicName = Sheets("照片").Cells.Find(rngData.Value, , , xlWhole) '使用Find方法在照片表的完整匹配姓名 If Not rngPicName Is Nothing Then rngPicName.Offset(0, 1).Copy rngData.Offset(0, 1) '如果有找到对应的姓名,则将照片复制粘贴到目标位置 Next End Sub
以上程式碼使用一刀切的方式刪除了舊有的圖片。
二不過…
儘管這段程式碼對於VBA基礎良好的朋友來說,稍微修改下,已經足夠應對大部分的問題,但是,對於小白而言,顯然不夠友善……
比如說……
1、照片的姓名固定在資料表的A列,實際情況,很可能不是A列,我說的對。
2、放置照片的位置固定於姓名列向右移動1列的單元格,實際情況,當然也很可能不是這樣,我說的還是對。
3、程式碼中將儲存照片的工作表固定設定為sheets(「照片」),實際情況,肯定很可能不是這樣,我英明…
4、程式碼未設定單元格的大小以適應圖片的大小,我…
程式碼修改如下:
Sub InsertPicFromSheet2() 'ExcelHome VBA编程学习与实践 by:看见星光 Dim rngData As Range, rngWhere As Range, cll As Range Dim rngPicName As Range, rngPic As Range, rngPicPaste As Range Dim shp As Shape, sht As Worksheet, bln As Boolean Dim strWhere As String, strPicName As String, strPicShtName As String Dim x, y As Long, lngYesCount As Long, lngNoCount As Long 'On Error Resume Next Set rngData = Application.InputBox("请选择应插入图片名称的单元格区域", Type:=8) '用户选择需要插入图片的名称所在单元格范围 Set rngData = Intersect(rngData.Parent.UsedRange, rngData) 'intersect语句避免用户选择整列单元格,造成无谓运算的情况 If rngData Is Nothing Then MsgBox "选择的单元格范围不存在数据!": Exit Sub strWhere = InputBox("请输入放置图片偏移的位置,例如上1、下1、左1、右1", , "右1") '用户输入图片相对单元格的偏移位置 If Len(strWhere) = 0 Then Exit Sub x = Left(strWhere, 1) '偏移的方向 If InStr("上下左右", x) = 0 Then MsgBox "你未输入偏移方位。": Exit Sub y = Val(Mid(strWhere, 2)) '偏移的值 Select Case x Case "上" Set rngWhere = rngData.Offset(-y, 0) Case "下" Set rngWhere = rngData.Offset(y, 0) Case "左" Set rngWhere = rngData.Offset(0, -y) Case "右" Set rngWhere = rngData.Offset(0, y) End Select strPicShtName = InputBox("请输入存放图片的工作表名称", , "照片") For Each sht In Worksheets If sht.Name = strPicShtName Then bln = True Next If bln <> True Then MsgBox "未找到保存图片的工作表:" & strPicShtName & vbCrLf & "程序退出。": Exit Sub Application.ScreenUpdating = False rngData.Parent.Select For Each shp In ActiveSheet.Shapes '如果旧图片存放在目标图片存放范围则删除 If Not Intersect(rngWhere, shp.TopLeftCell) Is Nothing Then shp.Delete Next x = rngWhere.Row - rngData.Row y = rngWhere.Column - rngData.Column '偏移的纵横坐标 For Each cll In rngData '遍历选择区域的每一个单元格 strPicName = cll.Text '图片名称 If Len(strPicName) Then '如果单元格存在值 Set rngPicName = Sheets(strPicShtName).Cells.Find(cll.Value, , , xlWhole) '使用Find方法在照片表完整匹配姓名 If Not rngPicName Is Nothing Then Set rngPicPaste = cll.Offset(x, y) '粘贴图片的单元格 Set rngPic = rngPicName.Offset(0, 1) '保存图片的单元格 lngYesCount = lngYesCount + 1 '累加找到结果的个数 If lngYesCount = 1 Then '设置放置图片单元格的行高和列宽,以适应图片的大小 rngPicPaste.RowHeight = rngPic.RowHeight rngPicPaste.ColumnWidth = rngPic.ColumnWidth End If rngPicName.Offset(0, 1).Copy rngPicPaste '如果有找到对应的姓名,则将照片复制粘贴到目标位置 Else lngNoCount = lngNoCount + 1 '累加未找到结果的个数 End If End If Next Application.ScreenUpdating = True MsgBox "共处理成功" & lngYesCount & "个对象,另有" & lngNoCount & "个非空单元格未找到对应的图片名称。" End Sub
以上程式碼解決了我們前面說的常見的三點問題…
然…三不過…
還是有一些實際應用中可能出現的問題未解決…
#比如說…
#1、如何解決圖片和資料來源的聯動性?當資料來源圖片更改的時候,資料表的圖片也會自動更改?嗯,除了重新運行程序,還可以使用工作表的激活事件,或者是使用activesheet.chartobjects.add……
2、如何設定圖片的大小適應單元格,而不是調整單元格的大小適應圖片?
相關學習推薦:excel教學
以上是Excel簡單搞定怎麼會依名稱查詢圖片的詳細內容。更多資訊請關注PHP中文網其他相關文章!