VBA auto-add image to cell from folder

menno_edeltrend

New Member
Joined
Nov 1, 2019
Messages
14
Dear mrExcellers,

In my company we work with a product database with calculations in it, every product offcourse has an unique article number. In the shared server we have a folder with pictures of every product with the article number as the title. We want to add the pictures automatically to every product with VBA, I know it is possible but my knowledge doesn't stretch far enough.

The article number stands in column D, the picture has to been placed in column B. The cel widht and hight are minimal, it would be nice to have the picture expending when you move the mouse over it.

I would like to let VBA start in the selected row and then go on from there till there is no article number in column D. That way it doesn't overwrite all the previous uploaded pictures.

I hope there is someone out there with the solution, thanks in advance!
 

Excel Facts

What do {} around a formula in the formula bar mean?
{Formula} means the formula was entered using Ctrl+Shift+Enter signifying an old-style array formula.
Try this to insert images.

Change folder for your folder name. In the cell you must put the name of the file and the extension. ex: art123.jpg

Code:
Sub Auto_Add_Image()
  Dim i As Long, wPath As String, wFile As String, sh As Worksheet
  If ActiveCell.Column <> 4 Then
    MsgBox "Select column D"
    Exit Sub
  End If
  If ActiveCell.Value = "" Then
    MsgBox "Select article number in column D"
    Exit Sub
  End If
  Set sh = ActiveSheet
  wPath = [COLOR=#ff0000]"C:\trabajo\images\"[/COLOR]
  For i = ActiveCell.Row To Range("D" & Rows.Count).End(xlUp).Row
    wFile = wPath & Range("D" & i)
    With sh.Pictures.Insert(wFile)
        .ShapeRange.LockAspectRatio = msoFalse
        .Top = Range("B" & i).Top + 1
        .Left = Range("B" & i).Left + 1
        .Width = Range("B" & i).Width - 2
        .Height = Range("B" & i).Height - 2
    End With
  Next
End Sub
 
Upvote 0
DanteAmor,

Thanks for yu reply! Unfortunately the code doesn't work. It gives a fault in the "With sh.Pictures.Insert(wFile)" line, do you have a solution for this? Also I would like to be able to choose the folder I want to use manually. I hope to hear from you!
 
Upvote 0
What does the error message say?


The name in the cell and in the folder must be identical.

In the cell you must put the name of the file and the extension. ex: art123.jpg

Try this please.

Code:
Sub Auto_Add_Image()
  Dim i As Long, wPath As String, wFile As String, Sh As Worksheet
  If ActiveCell.Column <> 4 Then
    MsgBox "Select column D"
    Exit Sub
  End If
  If ActiveCell.Value = "" Then
    MsgBox "Select article number in column D"
    Exit Sub
  End If
  Set Sh = ActiveSheet
  With Application.FileDialog(msoFileDialogFolderPicker)
    .Title = "Selecciona una carpeta"
    .AllowMultiSelect = False
    .InitialFileName = ThisWorkbook.Path & "\"
    If .Show <> -1 Then Exit Sub
    wPath = .SelectedItems(1) & "\"
  End With
  For i = ActiveCell.Row To Range("D" & Rows.Count).End(xlUp).Row
    wFile = wPath & Range("D" & i)
    If Dir(wFile) <> "" Then
      With Sh.Pictures.Insert(wFile)
          .ShapeRange.LockAspectRatio = msoFalse
          .Top = Range("B" & i).Top + 1
          .Left = Range("B" & i).Left + 1
          .Width = Range("B" & i).Width - 2
          .Height = Range("B" & i).Height - 2
      End With
    Else
      MsgBox "The file does not exist: " & wFile
    End If
  Next
End Sub
 
Upvote 0
Unfortunately it doesn't work, the code now sets the folder that I select as the .jpg, while I want the code to search in the folder for the right combination of article number.jpg. I think the solution is very close but I can't figure it out.
 
Upvote 0
Unfortunately it doesn't work, the code now sets the folder that I select as the .jpg, while I want the code to search in the folder for the right combination of article number.jpg. I think the solution is very close but I can't figure it out.

The code provided to you sets the path of the JPG files (wPath), and then completes the filename (wFile) by sourcing the information from Column D. If the names in Column D don't match what's on your computer exactly it won't work, but that isn't an issue with the code.

One way of checking might be to get a list of all the files in the directory and copy them across as-is; remove the path info; and then run the code.
 
Upvote 0
It worked with the first code with a fixed folder instead of the folder selection like in the second code, to the filenames should be correct. The code now says somethng like folder_name.jpg doesn't exist, t doesn't say that article_number.jpg doesn't exist. So it sets the folder as the image instead of the image in the folder.
 
Upvote 0
For the second code.Check the following:

ed25576d25cb2c381170dffb3eea9b71.jpg


------------------------------
f4f7e38cd7d80b01a1f4917c868beeb5.jpg
 
Upvote 0

Forum statistics

Threads
1,225,739
Messages
6,186,746
Members
453,370
Latest member
juliewar

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top