Excel VBAのことでお聞きしたいことがあり、ご教授お願いします。
下記の3つの図形があり、この3つをそのまま一番最後の図形(黄色)の後ろにコピペをしたいのですが、どのようにコードをかいたらよいのでしょうか、、?
又、上記の事を繰り返し行う場合の書き方も教えて欲しいです…
今まで試みたこと↓
○グループ化(マクロで出来なかった) 警告文:選択した図形はグループ化出来ませんでした。 と出ました。
ざっくりで申し訳ございませんが、何かヒントやアドバイスを頂ければ幸いです。よろしくお願いします。
No.3ベストアンサー
- 回答日時:
こんにちは
変数iが出てきて良く分からなくなりました
VBA実行前に3組の図形が沢山あるのでしょうか? iでループする分
それとも、3つの図形があり、それを重ねてグループにして
任意の回数分 複製し重ねる(又は移動)するのでしょうか?
それとも、沢山ある図形をすべて同じ位置に重ねるのでしょうか?
また、元図形はどうするのでしょうか? 移動する?それともそのまま残す?
レイヤーの順序はどうしますか?
あと、図形の名前を利用するのは良いのですが、コピペの場合
少し面倒かも知れませんね
例として
素材をコピペ、重ねてグループに グループにした図形をコピペですと
Dim shp1 As Shape, shp2 As Shape, shp3 As Shape
Set shp1 = ActiveSheet.Shapes("四角")
Set shp2 = ActiveSheet.Shapes("a四角")
Set shp3 = ActiveSheet.Shapes("b四角")
shp1.Copy
Range("D5").Select
ActiveSheet.Paste '貼り付け
Set shp1 = Selection.ShapeRange(1)
shp2.Copy
Range("D5").Select
ActiveSheet.Paste '貼り付け
Set shp2 = Selection.ShapeRange(1)
shp3.Copy
Range("D5").Select
ActiveSheet.Paste '貼り付け
Set shp3 = Selection.ShapeRange(1)
'選択してグループ化
shp1.Select Replace:=False
shp2.Select Replace:=False
shp3.Select Replace:=False
Selection.ShapeRange.Group
'この下をループする?
Selection.Copy
Range("D10").Select
ActiveSheet.Paste '貼り付け
Range("A1").Select
素材画像が同じサイズなら 同じセルにコピーするので位置はセル位置となり調整は不要かと・・
1つずつコピペは
For Each sName In Array("四角", "a四角", "b四角")
ActiveSheet.Shapes(sName).Copy
ActiveSheet.Paste Destination:=Range("D5")
こんな書き方も出来ますが、後でグループにする時に少々困ります
また、任意の名前を付けて配列に入れ
Selection.ShapeRange(1).Name =?&n
ary(n) = Selection.ShapeRange(1).Name
ActiveSheet.Shapes.Range(ary).Select
みたいなやり方も出来るかもしれませんが、確認していません
すべての図形を重ねてグループ、グループをコピペなら
もう少しすっきりかけると思います・・
最終的にどのようにしたいのか・・・
図形を沢山コピペした時に その後どのように使うのでしょう?
沢山ある場合は、どのような名前を付けるか・・など 課題がありそうですね
タイムアップで失礼します
No.2
- 回答日時:
こんばんは
まず、シェイプを特定する必要があります
例えば、テーマからでサンプル画像の場合(ForeColor.RGBで色を特定)
12874308などは適時調べて変更
Sub sample()
Dim shp As Shape, 青 As Shape, オレンジ As Shape, 黄 As Shape
For Each shp In ActiveSheet.Shapes
Select Case shp.Fill.ForeColor.RGB
Case 12874308
Set 青 = shp
Case 3243501
Set オレンジ = shp
Case 49407
Set 黄 = shp
End Select
Next
各Shapeに対して・・・コピペ?
黄色は1つで良いの?ループってたくさん重なった図形を作るのでは?
移動かな?
まサンプルで
青をコピーして任意の位置にペースト、黄位置に移動(サイズの言及がないので割愛)
青.Copy
Range("D5").Select
ActiveSheet.Paste '貼り付け
Set 青 = Selection.ShapeRange(1)
青.Left = 黄.Left
青.Top = 黄.Top
オレンジも青同様
オレンジ.Copy
Range("D5").Select
ActiveSheet.Paste '貼り付け
Set オレンジ = Selection.ShapeRange(1)
オレンジ.Left = 黄.Left
オレンジ.Top = 黄.Top
背面に移動
'オレンジを最背面
オレンジ.Select
Selection.ShapeRange.ZOrder msoSendToBack
'青を最背面
青.Select
Selection.ShapeRange.ZOrder msoSendToBack
'結果上から黄色オレンジ青で重なる
この重なった図形をグループ化
各図形オブジェクトを選択してグループ 名前も付けときます
'選択してグループ化
青.Select Replace:=False
オレンジ.Select Replace:=False
黄.Select Replace:=False
' Selection.ShapeRange.Group.Name = "Group1"
図形の選択を解除
Range("A1").Select
End Sub
一応、コード部分で実行可能かと思いますが
>上記の事を繰り返し行う場合
どの様な条件で繰り返すのでしょう?
どの様に図形を特定するかが問題ですね 2度目は同じ色の図形があるので
ずばり名前で特定した方が良いと思います
グループにした同じ3枚の図形を沢山作るのなら、最初に黄色をコピペ
グループにした後に移動のような手順でしょうか?
詳しくご回答いただきありがとうございます!!
色でやるやり方もあるんですね!勉強になります!
図形に名前をつけてみました!下にも続く予定なので、for i =1 to 図形のカウントをして、"四角"&i 、"a四角"&i、''b四角"&i と3つの図形に名前をつけました!最後の[''b四角"&i]の後に3つの図形を繰り返しおいていきたいです。(これからの計画としましては、A列に繰り返し回数の数字を入力し、その回数分、最後の[''b四角"&i]の後に3つの図形を置くことを繰り返したいです…。わかりにくい説明でごめんなさい。ご教授のほど宜しくお願いします。
No.1
- 回答日時:
こんにちは
>後ろにコピペをしたいのですが、~
「後ろ」というのは前後の後ろの意味で良いのでしょうか?
サイズがわからないけれど、添付図の見た目では橙色の幅の方が黄色より大きそうなので、はみ出てしまいそうな気がしますが・・
メソッド等は「マクロの記録」でも取ってみればわかると思いますが、概ね以下の手順でできるのではないでしょうか?
1)対象の図形をコピペ
2)図形位置を目的の図形(黄色)の位置に合わせる
3)前後位置(ZOrde)を最背面に移動
※ 中心位置合わせにしたい場合は、Left、Topに幅・高さの1/2を加えた位置が同じになるように計算すれば良いでしょう。
ありがとうございます!!マクロの記録でやっても、上手くいきませんでした、、なぜか図形の大きさが変わってしまったり、グループ化して移動しようと考えていたのですが、マクロの記録だと上手く読み込む事が出来ませんでした…
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) Excelのvbaについて教えてください。 図形一つ一つに名前がついています。 指定した図形の名前を 2 2022/08/04 15:13
- Excel(エクセル) Excel ガントチャートについてご教授ください。 実績時間をガントチャートに表したいと思っています 2 2022/04/14 09:21
- Visual Basic(VBA) Excel vbaについて知恵もしくは、コード教えて下さいm(__)m ① 表にあるデータをコピー、 2 2022/09/01 23:57
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/06/04 09:39
- Excel(エクセル) エクセルについて教えてください。 2 2023/06/14 11:11
- PowerPoint(パワーポイント) ExcelのVBAコードについて教えてください。 3 2022/05/25 14:32
- その他(Microsoft Office) ワードのマクロについて教えてください。 1 2023/01/22 11:43
- Visual Basic(VBA) Vba UserFormを前面に出す方法を教えてください 1 2023/08/17 11:08
- Excel(エクセル) Excelのマクロについて教えてください。 4 2022/05/31 14:07
- Excel(エクセル) 複数のExcelブックのシート1の内容を1つのExcelブックにコピー貼り付けたいのでvbaコードを 7 2023/02/10 23:20
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
pdf上に描画した図形が印刷され...
-
PowerPointで台形を描く方法
-
線を組み合わせた図形の塗りつ...
-
Excel のバージョンによって、...
-
Illustratorでくくり括弧記号を...
-
AutoCADで渦巻きを描く方法
-
ワードかエクセルの図形を使っ...
-
Canvaの図形は、縦横比をキープ...
-
エクセルVBAで図形のテキストを...
-
Jw-cad の図形リストが表示でき...
-
Excel 図形へのハイパーリンク
-
【VBA】3個の図形をコピーしてS...
-
Illustratorで白い部分のみを透...
-
パワーポイントで作成した複数...
-
WordファイルをHTML形式に変更...
-
エクセルでのオートシェイプの...
-
エクセル ユーザーフォームに...
-
図形でしずく型を作りたい
-
Excel2003図-扇形を書く方法は...
-
WORDで図に網掛けする方法は?
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
PowerPointで台形を描く方法
-
pdf上に描画した図形が印刷され...
-
線を組み合わせた図形の塗りつ...
-
ワードかエクセルの図形を使っ...
-
AutoCADで渦巻きを描く方法
-
Excel のバージョンによって、...
-
Canvaの図形は、縦横比をキープ...
-
グーグルスプレッドシートの図...
-
図形でしずく型を作りたい
-
エクセルで図形を連動させたい
-
Excel 図形へのハイパーリンク
-
Illustratorでくくり括弧記号を...
-
Excel2003図-扇形を書く方法は...
-
エクセル ユーザーフォームに...
-
クリックしたらパネルがめくれ...
-
G.CREWの使い方
-
WORDで図に網掛けする方法は?
-
Jw-cad の図形リストが表示でき...
-
エクセルVBAで図形のテキストを...
-
図形とビットマップの違いは?
おすすめ情報