工事写真をエクセルに大量に貼り付けています。
一枚一枚貼っているととても時間がかかるので、選択した写真を一度に貼り付けられるマクロを探しています。
エクセルが分からないためサイトからコードを拝借して使っているのですが、うまくいかなくて困っています。
①リンク貼り付けになってしまう
Shapes.AddPictuerメソッドを使わないといけないらしいのですが、直し方が分かりません。
②結合セルにぴったり合わない
右側だけがはみ出したり、足りなかったりします。
エクセル2013を使っています。
普通セル→結合セル→普通セルと縦に並んでいて、
結合セルに写真がぴったりと張り付くようにしたいです。
以下使っているコード
Sub Test()
Dim fName,pict As Picture
fName=Application.GetOpenFilename("JPG,*.jpg",MultiSelect:=True)
If IsArray(fName)Then
For I=1 To UBound(fName)
Set pict=ActiveSheet.Pictures.Insert(fName(i))
pict.TopLeftCell=ActiveCell
pict.Width=ActiveCell.Width
pict.Height=ActiveCell.Height
ActiveCell.Offset(2,0).Activate
Next I
End If
End Sub
本当は自分で勉強するべきだとは思いますが、提出期限が近く焦っているので質問しました。
よろしくお願いします。
No.2ベストアンサー
- 回答日時:
結合されたセルの大きさぴったりに、リンクでなく写真入れるサンプルです。
Sub Test()
Dim fName As Variant
Dim pict As Shape
fName = Application.GetOpenFilename("JPG,*.jpg", MultiSelect:=True)
If IsArray(fName) Then
For i = 1 To UBound(fName)
With ActiveCell
Set pict = ActiveSheet.Shapes.AddPicture(Filename:=fName(i), LinkToFile:=False, SaveWithDocument:=True, _
Left:=.Left, Top:=.Top, Width:=.MergeArea.Width, Height:=.MergeArea.Height)
End With
ActiveCell.Offset(2, 0).Activate
Next i
End If
End Sub
No.3
- 回答日時:
補足コメントより
いくつのセルを結合しているかによります。
データがこわれるわけではないので、ご自分でやってみる事をお勧めします。
そうしないとスキルアップになりませんので。
No.1
- 回答日時:
こんな感じで、できそうですが・・・あまり自信がないので、ご参考程度に。
Sub Test()
Dim fName, pict As Picture
Dim i
fName = Application.GetOpenFilename("JPG,*.jpg", MultiSelect:=True)
If IsArray(fName) Then
For i = 1 To UBound(fName)
Set pict = ActiveSheet.Pictures.Insert(fName(i))
pict.ShapeRange.LockAspectRatio = msoFalse
pict.ShapeRange.Width = ActiveCell.Width
pict.ShapeRange.Height = ActiveCell.Height
ActiveCell.Offset(2, 0).Activate
Next i
End If
End Sub
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
推しミネラルウォーターはありますか?
推しミネラルウォーターがあったら教えてください
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
エクセル マクロ写真帳に一括で写真を張り付けたいです。
Visual Basic(VBA)
-
【EXCEL VBA】ダブルクリックでセルのサイズに合わせて画像を挿入に機能を追加したいです。
Visual Basic(VBA)
-
任意フォルダから画像をすべてエクセルの指定マスに貼り付けをしたい
Visual Basic(VBA)
-
-
4
エクセルのVBAを使用し、工事写真台帳を作成しています。
Excel(エクセル)
-
5
Excel 画像貼り付けのVBAについて
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセル: セルの枠を超えて表示
-
Excel countif関数で取り消し線...
-
セルは大きくさせず、中の文字...
-
エクセルの白黒の反転で困って...
-
エクセルで1つのセルにスクロ...
-
Excelでcsvやtxtで保存する時に...
-
エクセルファイルに _x000D_ と...
-
VBA:結合されたセルに対する「...
-
エクセル2013で英単語を折り返...
-
Excel入力で勝手にエンター押さ...
-
セルを結合しても、文字をセル...
-
CSVファイルでテキストの改行の...
-
エクセルで右隣のセルより優先...
-
Excel 隣のセルに文字を表示さ...
-
マクロでセルの右から2番目の...
-
セル内の一部の文字だけをハイ...
-
エクセルの入力規則プルダウン...
-
Mp3tagの使い方について
-
マウスポインターが白十字のまま
-
セルの結合について(3行中2行...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセル: セルの枠を超えて表示
-
Excel countif関数で取り消し線...
-
セル内の一部の文字だけをハイ...
-
エクセルで1つのセルにスクロ...
-
エクセルファイルに _x000D_ と...
-
Excelでcsvやtxtで保存する時に...
-
マウスポインターが白十字のまま
-
エクセルの白黒の反転で困って...
-
セルを結合しても、文字をセル...
-
セルは大きくさせず、中の文字...
-
エクセルでセルを上下に結合し...
-
エクセルで画像を透過させて画...
-
エクセル2013で英単語を折り返...
-
エクセルで右隣のセルより優先...
-
Excel入力で勝手にエンター押さ...
-
エクセルの入力規則プルダウン...
-
VBA:結合されたセルに対する「...
-
エクセル 折り返して全体を表...
-
Excel 隣のセルに文字を表示さ...
-
エクセルのセル外改行は可能で...
おすすめ情報
今日試してみたところ、うまくいきました!
すごくさくさく仕事が進みます!
本当にありがとうございました(^^)
ちなみになんですが、教えていただいたコードを少し変えて、
1つ目の結合セルの次に4つ目の結合セルに写真を張り付けるようなコードにも出来るでしょうか。
Offset(2,0)のところをOffset(6,0)にすれば
いいのでしょうか。
もし宜しければ教えてください。