
商品リストを作っています。
エクセルシートのC列に商品名が入っています。(6桁の数字&アルファベット。たとえばA00123)
フォルダにその商品名をつけた画像がまとまっています。
B列に、その該当する画像を自動的に貼り付けたいのですがどうすればいいですか?
画像数は1000個くらいフォルダに入っています。毎週増えます。
エクセルに載せる数はそのうち半分くらいです。
画像がない場合もあるのでその場合は何かしらのエラーを表示させたいです。
マクロはド初心者です。切り貼りくらいしか出来ません。が、今勉強中です。
検索して下記の方法を見つけたのですが、未だ成功していません。
http://oshiete.goo.ne.jp/qa/2880877.html
こちらをALT+F11ででできた画面に張るまではよかったのですが、
実行しようとしても何も出てこず失敗しました。
(他のときは選択する名前が出てくるのですが。Subの後に入っている名前です。このリンクのだとsubがなくて名前がないため、マクロ実行できません)
http://oshiete.goo.ne.jp/qa/5890088.html
コピペして実行したのですが何もかわりませんでした。
ファイルがおいてある場所は "c:\あるフォルダ\"から "c:\picpic\"にかえました。
私のリストは商品名がB列にあるのですがそれが問題なのでしょうか。
excel2010
windows7
フォルダはマイドキュメントにあります。名前はpicpicです。
何か不足している情報がありましたら教えてください。
よろしくお願いいたします。
No.1ベストアンサー
- 回答日時:
添付画像はこちらで実行した結果です。
hermosa90254さんが貼り付けておられたURLに書かれていたプログラムを一部修正したものです。
ExcelでVBE画面(Alt + F11)に下記プログラムをそのままコピペして実行してみてください。
ただし「写真の保存場所」で書かれているマイドキュメントのパスはご自身のパソコンのエクスプローラでご確認下さい。
(念のためVBE画面での操作手順画像を次の回答で添付します)
Sub macro1()
Dim p As String
Dim h As Range
'写真の保存場所
p = "C:\Users\☆☆☆\Documents\picpic\"
'現在表示されている写真は一度削除する
ActiveSheet.Pictures.Delete
'商品名が入力されている行まで繰り返す
For Each h In Range("D2:D" & Range("C1048576").End(xlUp).Row)
'写真ファイルが保存されている時
If Dir(p & h) <> "" Then
With ActiveSheet.Pictures.Insert(p & h)
.Name = h
'写真ファイル名が入力されているセルから2つ左のセルに挿入
.Top = h.Offset(0, -2).Top
.Left = h.Offset(0, -2).Left
'写真サイズの設定
.Width = h.Offset(0, 1).Width
.Height = h.Offset(0, 1).Height
End With
End If
Next
End Sub

この回答への補足
picopico_7さん
回答本当にありがとうございます!返事がかなり遅くなってしまい申し訳ありません。
おっしゃるとおりやってみたのですが、
Run-time error '1004':
Unable to set the Name property of the Picture class
というエラーが出てしまいます。
endかdebugか選べたのでDEBUGをしたところ、.Name = h のところが黄色でハイライトされました。
大変お手数ですが、解決方法をいただけますでしょうか?
よろしくお願いいたします。
No.2
- 回答日時:
#1です。
前回回答の際、「念のためVBE画面での操作手順画像を次の回答で添付します」と記しましたが連続回答することが出来ないとは知らず、意味不明な文章となってしまいました。
失礼いたしました。
実行エラーとなった「 .Name = h」部分は削除して再度実行してみてもらえますか?
今回の処理ではこの部分は不要でした。
引用プログラムだったため削除し忘れです。
重ね重ね失礼いたしました(+_+)
また違うエラーが出たら補足してください。
回答ありがとうございます!
これ自体はなぜかもう一度したら出来ました!
しかし、このエクセルファイルをメールで他の人に送るとエラーが出て画像が表示できないようです。
新たに質問をしたので、可能であればこちらも教えて頂けませんでしょうか?
http://oshiete.goo.ne.jp/qa/8367424.html
よろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
マクロで画像挿入→エラー「リンクされたイメージを表
Excel(エクセル)
-
Excel セルに入力した画像名からフォルダの画像を自動表示させたい
Excel(エクセル)
-
エクセルで次々と画像を表示させたい
Excel(エクセル)
-
-
4
エクセルのセルに指定画像(.jpg)を自動で貼り付けたいです。
Excel(エクセル)
-
5
Excelで数字を入れたら対応する図を呼び出したい
Excel(エクセル)
-
6
エクセルのマクロで特定フォルダ内のJPGファイルを検索して開きたいので
Excel(エクセル)
-
7
エクセル、画像ファイル名の書かれたセル(複数個所)に画像を一括で表示させる方法
Excel(エクセル)
-
8
任意フォルダから画像をすべてエクセルの指定マスに貼り付けをしたい
Visual Basic(VBA)
-
9
【VBA】写真の縦横比を変えずに貼り付ける
Visual Basic(VBA)
-
10
excelにて。VBAで、フォルダ内の画像を一覧の横に表示させたい。
Excel(エクセル)
-
11
VBAでセルを指定した画像のコピー&ペーストを繰り返したい
Excel(エクセル)
-
12
条件に一致したときに画像を表示したいのですが・・。
Excel(エクセル)
-
13
VBAエクセルに貼り付けた画像をセルにあった大きさにしたい(等倍)
Excel(エクセル)
-
14
エクセルVBA 画像を貼り付けるセル位置を指定する方法
Excel(エクセル)
-
15
エクセルに張り付けた写真のファイル名が見たい
Microsoft ASP
-
16
Excel2019 マクロを使用し画像を貼り付けした際のリンク切れについて
Excel(エクセル)
-
17
VBA フォルダ名と画像ファイル名取得
Visual Basic(VBA)
-
18
Excel 画像貼り付けのVBAについて
Excel(エクセル)
-
19
VBAの内容の修正をお願いさせて頂きます
Excel(エクセル)
-
20
EXCELのVBAで画像を選んだ順に貼り付ける方法
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
コマンドプロンプトのエラーに...
-
「win11-23H2」を「win11-24H2...
-
Windowsアプリケーションをメモ...
-
VBscriptが起動しない?
-
バッチファイルで以下のような...
-
.NETからストアドプロシージャ...
-
exeファイルを実行するとコマン...
-
cygwin上でvbscirptを実行する方法
-
これってパソコンの最適化が完...
-
[teraterm] waitコマンドで停止...
-
エクセルのVBAについて とある...
-
ftpコマンドを実行すると「425 ...
-
win10の「フォト」で、「次へ」...
-
大量のフォルダからひとつのフ...
-
一括でフォルダと同じ名前にフ...
-
コマンドプロンプトの「%1」と...
-
.htaccess で読み込む .htpassw...
-
複数の既成インストーラを連係...
-
.txtではなく.logの方が良いの...
-
パソコンのフォルダー内のファ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
コマンドプロンプトのエラーに...
-
「win11-23H2」を「win11-24H2...
-
[teraterm] waitコマンドで停止...
-
「読み取りと実行」と「読み取...
-
これってパソコンの最適化が完...
-
バッチファイルの内容を表示さ...
-
exeファイルを実行するとコマン...
-
複数のbatファイルを自動実行し...
-
VBscriptが起動しない?
-
ExcelのVBAが特定のPC上でのみ...
-
Excel(エクセル) VBA プロシー...
-
Windows System32 Security Hea...
-
PDFファイルを開き、印刷し、閉...
-
VBScriptでコマンドプロンプト...
-
batからexeを実行し戻り値を受...
-
Access の VBA 実行中に他の操...
-
Excel VBA ステップインが途中...
-
【VB.NET】exeを実行すると「発...
-
バッチファイルが不正終了して...
-
VBA 既に開いているBookに継続...
おすすめ情報