
excelvba初心者です。
お手数おかけします。
難問なのかどうかもよく分からず。。困っています。
シート1 シート2 シート3
AAA 100 AAA 50 BBB 20
BBB 200 CCC 150 CCC 30
DDD 300 QQQ 250 DDD 10
EEE 400 WWW 350 RRR 40
上記の値を決められた順番に別シートに集計したい(その時に、値を1/10にしたい)
シート4
AAA 150
BBB 220
CCC 180
DDD 310
EEE 400
FFF 0
GGG 0
www 350
findでAAAを検索し見つかった値を ifにて条件分岐させるものをつくったものの
プロシャーシーが大きすぎと言われてできません。
どなたか教えていただけないでしょうか。
No.3ベストアンサー
- 回答日時:
てきとーだけど、分かりやすく書いたつもり・・・
ステップ実行やローカルウィンドウ使って、確認してください。「確認用」の行は消していい。VBEのヘルプ(FindNextで検索)にサンプルコード載ってることもあるから、見てみるといいかも。
Sub zzz()
Dim sh_mst As Sheet, sh As Sheet
Dim rng As Range, c As Range
Dim r, n
Set sh_mst = Sheets("マスター")
'マスターループ
r = 1
Do While sh_mst.Cells(r, 1) <> ""
skey = sh_mst.Cells(r, 1)
n = 0
'シートループ
For Each sh In Sheets
If sh.Name <> "マスター" Then
sh.Select '確認用
'--> 検索処理
Set rng = sh.Range("A:A")
Set c = rng.Find(skey, LookIn:=xlValues)
If Not c Is Nothing Then
c.select '確認用
firstAddress = c.Address
Do
n = n + c.Offset(0, 1).Value
Set c = rng.FindNext(c)
c.select '確認用
Loop While Not c Is Nothing And c.Address <> firstAddress
End If
'<-- 検索処理
End If
Next 'sh
sh_mst.Cells(r, 2) = n / 10
r = r + 1
Loop 'sh_mst
End Sub
朝早く回答ありがとうございます。
わかりずらい返信に対し理解していただき
感謝しております。
なにぶんにも、素人なもので。。もっともっと出来るように
ならなくてはと。。。
今回のいただいたプログラムにより出来そうです。
あとは、今作っているやつに自分でアレンジしていけばと思います。
今回1列のみの計算ですが、2列を対象にして計算させるにはとか。。まだまだ分かりません。
今から勉強することは山積みですが、一度いただいたものをアレンジして
挑戦していきたいと思います。
どうしても分からない場合は、再度、質問させていただきますので
その時は、よろしくお願い致します。
ありがとうございました。
No.2
- 回答日時:
手書きでサイズオーバーか・・・がんばりましたね。
。。あまり複雑になると、メンテナンスも困難になるので、なるべくループして同じ処理を減らすといいです。繰り返す部分を関数化しちゃう手もあります。
記録ベースでも、選択セルとか工夫すれば、Selectionを基準にループできることも多いですよ。
For でも Do でも、同じことできるからお好みで。
'↓よく使うループのパターン
Do While Selection <> ""
Selection.Offset(1, 0).select '空じゃなければ次
Loop
r = 1
Do While Cells(r, 1) <> ""
Cells(r, 1) = r
r = r + 2 '2行おきに処理
Loop
For r = 1 to 100
Cells(r, 1) = "1~100行まで処理"
Next
For each sh in Sheets
sh.Range("A1").Select '全てのシート
If sh.Name <> "マスター" then
sh.Tab.ColorIndex = 1 'マスター以外
End if
Next
No.1
- 回答日時:
> プロシャーシーが大きすぎと言われてできません。
「プロシージャ」は、Sub ~ End Sub の処理ブロックのことです。何行あるんだろう、ありえないくらいデカイはず・・・
記録は、なるべくムダな操作減らしてシンプルに、ですよ。
再記録大変なので、まずはムダな処理を削除してみてください。
こーいうの↓で埋め尽くされてませんか?
ActiveWindow.ScrollRow = 数字
画面スクロールなので、その行は削除しちゃって大丈夫です。
それで動かないかな
この回答への補足
回答ありがとうございます
自分で一から作ったため、余分なものが入っていないと思います。。
自分では、作り方が悪いのかと。。
現在、シート1、シート2、シート3、マスターのシートを使っております。
マスターの文字を正として、シート1、シート2 で文字が一致すると
シート3のセルの指定して位置へ (シート1+シート2)/1000で値を入力しようと考えました。
この時に、find とif then を使用していますが、
条件不一致の時にエラーが出てしまうため、条件分岐がとてつもなく多くなっています。
loopとか?使えればいいのですが。。この部分が未知なもので。。
アバウトの書き方なので、いまいち説明できていません。
申し訳ありません
お付き合いしていただけたら、幸いです。
よろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) ¥マークを含むパスの処理について(マクロ、または関数) 2 2022/12/25 02:11
- SQL Server ACCESSで3ファイルを結合して、表を作成するやり方を教えて下さい。 17 2022/08/15 20:34
- SQL Server ACCESSで複数テーブルを結合して、リストを作る方法を教えてください。 2 2022/08/12 19:32
- SQL Server ACCESSで表が作りたく、そのためのSQL文や設定方法を教えてください。 1 2022/08/15 12:28
- Visual Basic(VBA) 【VBA】特定の文字で改行(次の行)に行きたい。 3 2022/04/11 17:20
- その他(データベース) カラム上の重複を削除するクエリを教えてください 3 2022/04/12 14:11
- Perl perl このテキストファイルを簡単に配列に入れるには? 2 2022/04/27 20:24
- JavaScript 指定したパスが現URLに含まれていたら特定要素を削除するJavascriptのコードを教えてください 2 2023/04/27 17:58
- JavaScript JavaScript|特定URLだった時、特定の要素を変更するコードの書き方を教えてほしいです 2 2023/08/25 21:43
- Excel(エクセル) VBAで、シート間の転記するコードを教えてください。 4 2023/03/26 10:43
関連するカテゴリからQ&Aを探す
洗濯機・乾燥機
掃除機・クリーナー・空気清浄機
エアコン・クーラー・冷暖房機
扇風機・冷風機・サーキュレーター
ヒーター・こたつ・ホットカーペット
加湿器・除湿機
照明・ライト
ミシン・アイロン
冷蔵庫・炊飯器
電子レンジ・オーブン・トースター
ホームベーカリー・ホットプレート・圧力鍋
コーヒーメーカー・電気ケトル・電気ポット
フードプロセッサー・ミキサー
ガスコンロ・IHクッキングヒーター・給湯器
ウォーターサーバー・浄水器・食器洗い乾燥機
体重計・体脂肪計・体組成計
歩数計・活動量計
体温計・血圧計
ドライヤー・ヘアアイロン
美顔器・脱毛器・電気シェーバー
電動歯ブラシ・電子タバコ
固定電話・IP電話・FAX
時計・電卓・電子辞書
バッテリー・充電器・電池
その他(生活家電)
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一番好きなみそ汁の具材は?
- ・泣きながら食べたご飯の思い出
- ・「これはヤバかったな」という遅刻エピソード
- ・初めて自分の家と他人の家が違う、と意識した時
- ・いちばん失敗した人決定戦
- ・思い出すきっかけは 音楽?におい?景色?
- ・あなたなりのストレス発散方法を教えてください!
- ・もし10億円当たったら何に使いますか?
- ・何回やってもうまくいかないことは?
- ・今年はじめたいことは?
- ・あなたの人生で一番ピンチに陥った瞬間は?
- ・初めて見た映画を教えてください!
- ・今の日本に期待することはなんですか?
- ・集中するためにやっていること
- ・テレビやラジオに出たことがある人、いますか?
- ・【お題】斜め上を行くスキー場にありがちなこと
- ・人生でいちばんスベッた瞬間
- ・コーピングについて教えてください
- ・あなたの「プチ贅沢」はなんですか?
- ・コンビニでおにぎりを買うときのスタメンはどの具?
- ・おすすめの美術館・博物館、教えてください!
- ・【お題】大変な警告
- ・洋服何着持ってますか?
- ・みんなの【マイ・ベスト積読2024】を教えてください。
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・最強の防寒、あったか術を教えてください!
- ・歳とったな〜〜と思ったことは?
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
excelの差込印刷で可視セルだけ...
-
エクセル:VBAで月変わりで、自...
-
vbaでコントロールブレイク
-
VBA 貼付先範囲(行)がいっぱ...
-
VBA:同じ文字列データの比...
-
Excel で行を指定回数だけコピ...
-
VBA 最終行取得からの繰り返し貼付
-
エクセルVBAで SendKeys "{TAB}"
-
Excel VBA 時刻でのD...
-
Excelマクロ データが上書きさ...
-
歯抜けの時間を埋めて行の挿入
-
VBA別シートの最終行の下行へ貼...
-
エクセル2007で、マクロで、結...
-
Excelでデータの抽出&別シート...
-
VBAで複数シート選択
-
Excelマクロで空白セルを詰めて...
-
EXCELマクロで全シート対...
-
Excel VBA インデックスの境...
-
スマホ機種変更で旧機種のGoogl...
-
機種変更時にデータは見られる?
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
excelの差込印刷で可視セルだけ...
-
Excel で行を指定回数だけコピ...
-
Excel VBA インデックスの境...
-
VBA別シートの最終行の下行へ貼...
-
エクセルVBAで 2種のリストを...
-
エクセル:VBAで月変わりで、自...
-
VBA:同じ文字列データの比...
-
VBA 貼付先範囲(行)がいっぱ...
-
Excel VBAでシート内全体に非表...
-
エクセルVBA 別シートの複数の...
-
歯抜けの時間を埋めて行の挿入
-
Excelマクロで空白セルを詰めて...
-
VBA 最終行取得からの繰り返し貼付
-
Excelマクロ データが上書きさ...
-
EXCELマクロで全シート対...
-
エクセル シート保護後コメン...
-
エクセルVBAで SendKeys "{TAB}"
-
Excelでデータの抽出&別シート...
-
VBAで複数シート選択
-
エクセル2007で、マクロで、結...
おすすめ情報