Thema Datum  Von Nutzer Rating
Antwort
16.12.2022 10:03:11 Clemens
NotSolved
Blau Bilder in Excelzelle einfügen
16.12.2022 11:36:56 volti
NotSolved
16.12.2022 14:01:22 Clemens
NotSolved

Ansicht des Beitrags:
Von:
volti
Datum:
16.12.2022 11:36:56
Views:
649
Rating: Antwort:
  Ja
Thema:
Bilder in Excelzelle einfügen

Hallo Clemens,

hier eine Idee dazu...

Teste mal.

Wichtig hierbei ist es auch, zu checken, ob die Bilddatei überhaupt vorhanden ist und ob es schon ein Bild in dieser Stelle gibt. So kann der Code mehrfach laufen, ohne dass immer wieder Bilder doppelt eingefügt werden.

Code:
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
 
Private Sub Bild_Einfuegen_und_Anpassen_aus_Datei4()
' Sub fügt ein Bild in eine Zelle/Bereich ein
' Eingefügt an gewünschter Stelle, Höhe/Breite werden angepasst
  Dim oPic     As Object, AC As Range
  Dim sPicFile As String, oShape As Object
  Dim iZeile   As Long, bBildda  As Boolean

  Const csPfad As String = "D:\Pictures\"                    ' Pfad <<<anpassen>>>

  With ThisWorkbook.Sheets("Tabelle1")
      For iZeile = 1 To .Cells(.Rows.Count, 3).End(xlUp).Row
          If .Cells(iZeile, "C").Value <> "" Then
             sPicFile = csPfad & .Cells(iZeile, "C").Value & ".jpg"

' Festellen, ob schon ein Bild in der Zelle drin ist
             bBildda = False
             For Each oShape In .Shapes
                 If oShape.TopLeftCell.Address = .Cells(iZeile, "A").Address Then
                    bBildda = TrueExit For
                 End If
             Next oShape

             If Dir$(sPicFile) <> "" And bBildda = False Then
' Bereich setzen, auch verbundene Zellen oder Range
                Set AC = .Cells(iZeile, "A").MergeArea

' Bild einfügen
                Set oPic = .Shapes.AddPicture(sPicFile, _
                FalseTrue, AC.Left + 1, AC.Top + 1-1-1)
                If Not oPic Is Nothing Then
                   If oPic.Width > oPic.Height Then        ' Querformat
                      oPic.Width = AC.Width - 2
                      If oPic.Height > AC.Height Then oPic.Height = AC.Height - 2
                      oPic.Top = AC.Top + ((AC.Height - oPic.Height) \ 2 ' zentrieren
                   Else
                      oPic.Height = AC.Height - 2          ' Hochformat
                      If oPic.Width > AC.Width Then oPic.Width = AC.Width - 2
                      oPic.Left = AC.Left + ((AC.Width - oPic.Width) \ 2 ' zentrieren
                   End If
                   Set oPic = Nothing
                End If
             End If

          End If
      Next iZeile
  End With
End Sub
_________
viele Grüße
Karl-Heinz

Ihre Antwort
  • Bitte beschreiben Sie Ihr Problem möglichst ausführlich. (Wichtige Info z.B.: Office Version, Betriebssystem, Wo genau kommen Sie nicht weiter)
  • Bitte helfen Sie ebenfalls wenn Ihnen geholfen werden konnte und markieren Sie Ihre Anfrage als erledigt (Klick auf Häckchen)
  • Bei Crossposting, entsprechende Links auf andere Forenbeiträge beifügen / nachtragen
  • Codeschnipsel am besten über den Code-Button im Text-Editor einfügen
  • Die Angabe der Emailadresse ist freiwillig und wird nur verwendet, um Sie bei Antworten auf Ihren Beitrag zu benachrichtigen
Thema: Name: Email:



  • Bitte beschreiben Sie Ihr Problem möglichst ausführlich. (Wichtige Info z.B.: Office Version, Betriebssystem, Wo genau kommen Sie nicht weiter)
  • Bitte helfen Sie ebenfalls wenn Ihnen geholfen werden konnte und markieren Sie Ihre Anfrage als erledigt (Klick auf Häckchen)
  • Bei Crossposting, entsprechende Links auf andere Forenbeiträge beifügen / nachtragen
  • Codeschnipsel am besten über den Code-Button im Text-Editor einfügen
  • Die Angabe der Emailadresse ist freiwillig und wird nur verwendet, um Sie bei Antworten auf Ihren Beitrag zu benachrichtigen

Thema Datum  Von Nutzer Rating
Antwort
16.12.2022 10:03:11 Clemens
NotSolved
Blau Bilder in Excelzelle einfügen
16.12.2022 11:36:56 volti
NotSolved
16.12.2022 14:01:22 Clemens
NotSolved