自己流でやっており下手なコードです・・・お知恵を拝借できればと思います!
アクディブセルを選択、写真挿入して複数枚の場合は隣のセルへ貼りつけのコードはできました。
これを指定セル2つに配置(E8とE9)にしようとしましたが、E8に写真が二枚貼りつけになってしまいました・・・
どこを変更したらいいのか、ご教授いただければ幸いです。
Sub 写真入れる()
Dim fName As Variant
Dim i As Long
Dim Pict As Picture
fName = Application.GetOpenFilename("JPGファイル, *.jpg", MultiSelect:=True)
If IsArray(fName) Then
Application.ScreenUpdating = False
'配列に格納されたファイル名をソート
BubbleSort fName, True
For i = 1 To UBound(fName)
Set Pict = ActiveSheet.Pictures.Insert(fName(i))
With Pict
.Top = Range("E8").Top '画像の上位置
.Left = Range("E8").Left '画像の左位置
.Width = Range("E8").Width 'セルの幅にリサイズ
End With
' 次の貼り付け先を選択(アクティブセルにする)
Select Case i Mod 1
Case 1 '次の写真(0,前の写真の何個下かを指定)
ActiveCell.Offset(1, 0).Select
End Select
Next i
End If
With Application
.StatusBar = False
.ScreenUpdating = True
End With
Set Pict = Nothing
MsgBox i - 1 & "枚の画像を挿入しました。", vbInformation
End Sub
No.1ベストアンサー
- 回答日時:
これでどうでしょうか?
Sub 写真入れる()
Dim fName As Variant
Dim i As Long
Dim Pict As Picture
fName = Application.GetOpenFilename("JPGファイル, *.jpg", MultiSelect:=True)
If IsArray(fName) Then
Application.ScreenUpdating = False
'配列に格納されたファイル名をソート
BubbleSort fName, True
For i = 1 To UBound(fName)
Set Pict = ActiveSheet.Pictures.Insert(fName(i))
'---ここから追加分1
Dim myCol As String
Dim myRow As Long
myCol = "E" '列の
myRow = "8" '行目から貼り付け開始
'ここまで追加分1---
With Pict
'---ここから変更1
.Top = Range(myCol & myRow + i).Top '画像の上位置
.Left = Range(myCol & myRow + i).Left '画像の左位置
.Width = Range(myCol & myRow + i).Width 'セルの幅にリサイズ
'ここまで変更1---
'---ここから追加分2
.Height = Range(myCol & myRow + i).Height 'セルの高さにリサイズ
'ここまで追加分2---
End With
' 次の貼り付け先を選択(アクティブセルにする)
Select Case i Mod 1
Case 1 '次の写真(0,前の写真の何個下かを指定)
ActiveCell.Offset(1, 0).Select
End Select
Next i
End If
With Application
.StatusBar = False
.ScreenUpdating = True
End With
Set Pict = Nothing
MsgBox i - 1 & "枚の画像を挿入しました。", vbInformation
End Sub
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
ロボットの住む世界で流行ってる罰ゲームとは?
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
複数の画像ファイルを挿入したい
Excel(エクセル)
-
エクセル マクロ写真帳に一括で写真を張り付けたいです。
Visual Basic(VBA)
-
エクセル、画像ファイル名の書かれたセル(複数個所)に画像を一括で表示させる方法
Excel(エクセル)
-
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBAマクロ実行時エラーの修正に...
-
エクセルVBA 配列からセルに「...
-
VBA:日付を配列に入れ別セルに...
-
特定の色のついたセルを削除
-
Excelで空白セル直前のセルデー...
-
【VBA】【ユーザーフォーム_Lis...
-
DataGridViewのフォーカス遷移...
-
エクセル VBA ボタンをクリック...
-
Excel UserForm の表示位置
-
EXCEL VBA 文中の書式ごと複写...
-
Excel VBAでCheckboxの名前を変...
-
関数の引数でrangeを指定したとき
-
【VBA】写真の貼り付けコードが...
-
マクロの実行時エラー'1004'が...
-
Excel VBAで特定の範囲の空白セ...
-
Excel 範囲指定スクショについ...
-
FlexGridのセル内文字を点滅さ...
-
入力規則のリスト選択
-
データのある範囲を選択するVBA...
-
下記のマクロの説明(意味)を...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBAマクロ実行時エラーの修正に...
-
エクセルVBA 配列からセルに「...
-
特定の色のついたセルを削除
-
Excel UserForm の表示位置
-
Excelで空白セル直前のセルデー...
-
【VBA】【ユーザーフォーム_Lis...
-
VBA:日付を配列に入れ別セルに...
-
【Excel VBA】一番右端セルまで...
-
Excel VBAでCheckboxの名前を変...
-
EXCEL VBA 文中の書式ごと複写...
-
入力規則のリスト選択
-
DataGridViewのフォーカス遷移...
-
【VBA】写真の貼り付けコードが...
-
CellEnterイベント仕様について
-
下記のマクロの説明(意味)を...
-
飛び地セルの空白判定
-
Excel 範囲指定スクショについ...
-
C# DataGridViewで複数選択した...
-
Excel VBA IF文がうまく動作し...
-
エクセルのカーソルを非表示に...
おすすめ情報