同じような質問を調べたのですが、私の問題とは一致するものがなくて、照会します。
Book1で算出した2種類の商品(A、B)の貸出数量を、Book2の同一日付欄に複写するマクロです。
Book1(sheet1)のデータ(複写元)
A B
1 2020/4/1
2 商品A 2 ←数量
3 商品B 5 ←数量
Book2のシート(複写先)<写真>
商品Aと商品B別に四半期毎の管理シートがあり、年度分の合計で8シートです。
シート名は、A4-6,A7-9,A10-12,A1-3,B4-6,B7-9,B10-12,B1-3で、全て同じフォームです。
2020年4月の場合、A列は3行目に年月(手入力)、6行目から36行目に日付(計算式)を表示しています。
作業は、
Book1で算出した2020/4/1の商品Aの数量(B2=2)をBook2「シートA4-6」のB6に複写します。続いて、商品Bの数量(B3=5)をBook2「シートB4-6」のB6に複写します。
上記作業を毎営業日繰り返します。
最後に、複写先のBook2のシートの作り方が処理を難しくしている気もします。4月から翌年3月末までのデータが一覧で見えれば良いので、シートの作り方を変えた方が良い場合には合わせてアドバイス下さい。
よろしくお願いいたします。
No.6ベストアンサー
- 回答日時:
>Set ws = Workbooks("Book2.xlsx").Worksheets(rr.Value & v(mm)) ' Book名の拡張子が不明でした・・・適宜修正を。
これを
Set ws = Workbooks("Book2.xlsx").Worksheets(Left(rr.Value, 1) & v(mm)) ' Book名の拡張子が不明でした・・・適宜修正を。
とすると、
>千4-6、千7-9、千10-12、千1-3
に対応できます。
めぐみん 様
今回も大変お世話になりました。
こんな難しいことできるのか半信半疑でお聞きしましたが、出来ました。
これから、コードの意味を勉強してスキルアップに繋げます。
これで、毎日の手入力作業の漏れを確実に解消することが出来ますし、他の処理にも応用できそうです。
御多忙中、丁寧に教えていただき感謝しております。
No.4
- 回答日時:
取り敢えず
>シート名については、商品名と期間を合わせた「千葉4-6」、「京葉4-6」でも全く構いません。
こちらのシート名でお願いします。
数字とハイフンは半角文字で宜しいでしょうか?
Sub megu()
Dim ws1 As Worksheet, ws As Worksheet
Dim r As Range, rr As Range
Dim m As Integer, mm As Integer
Dim d As Integer, v As Variant
Set ws1 = ThisWorkbook.Worksheets("Sheet1")
Set r = ws1.Range("A2", ws1.Cells(Rows.Count, "A").End(xlUp))
v = Array("4-6", "7-9", "10-12", "1-3") '月は半角として。全角の場合はこの部分を書き直せばOKかと。
m = IIf(Month(ws1.Range("A1").Value) < 4, Month(ws1.Range("A1").Value) + 8, Month(ws1.Range("A1").Value) - 4)
mm = Int(m / 3)
m = (m Mod 3) * 5
d = Day(ws1.Range("A1").Value)
For Each rr In r
Set ws = Workbooks("Book2.xlsx").Worksheets(rr.Value & v(mm)) ' Book名の拡張子が不明でした・・・適宜修正を。
ws.Range("A5").Offset(d, m + 1).Value = rr.Offset(, 1).Value
Set ws = Nothing
Next
Set r = Nothing
Set ws1 = Nothing
End Sub
No.3
- 回答日時:
No.2です。
>最後に、複写先のBook2のシートの作り方が処理を難しくしている気もします。
>4月から翌年3月末までのデータが一覧で見えれば良いので、シートの作り方を変えた方が良い場合には合わせてアドバイス下さい。
No.2の補足から判断した時、現状のシートの作り方であってもコード作成について言うなら難易度はさほど変わりません。
シートの作り方のアドバイスって点では業務に携わってないのでより良い方法を伝える事は出来ません。(ごめんなさい。)
ただそちらの希望にある『4月から翌年3月末までのデータが一覧で見えれば良い』とは、今の四半期毎にシートを分けるのは業務的に不具合があると受け取って宜しいのかな?
それであれば『項目名』毎のシートで作成しておき表を4~3月で横並びにしてしまうとか?
この辺は使う側の使いやすさになりますしね。
四半期毎にする事で途中集計に使いやすいって点も回答者側には思い浮かんでも実際そうなのかはわかりませんし。
No.2
- 回答日時:
まず『商品A』は仮の姿。
(ですよねぇ?)ではシート名の『A』はどうなるの?
例えば『みかん』と言う商品名でシート名が『みかん4-6』なら突き合わせる語句が一致しますよね?
でも今回はどう突き合わせる事が出来るのか?(どこでどんな条件で切り抜けばよいのか?本当に”A”と言う文字が使われているとも思えなくて)
最初の件は毎営業日って事は月に数回は作業をすると受け取れました。
ではある日の作業である日付に数値を入れました。
数日後に以前入れた日付にまた数値を入れる事があるのかないのか?
あるとしたら以前の数値に加算する?
それとも同日への入力は2回以上行われない?
と言う感じです。
No.1
- 回答日時:
毎営業日にこの作業をやっておられて仮にですが『既に値のあるセル(月日と商品記号?)が次の作業で同じだった場合』はどのようになるのでしょう?
あと複写元のA列の値は『商品A』なのか『A』だけなのか。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- その他(Microsoft Office) Excelで総数量を変動させたい 2 2022/11/04 23:49
- Excel(エクセル) エクセルの条件付き書式 個人シートを参照して集計シートに色付けしたい 1 2023/06/22 00:39
- Excel(エクセル) Excelマクロ 差分抽出の方法が知りたいです。 2 2023/03/07 13:25
- Visual Basic(VBA) VBAコードで質問があります 2 2022/10/20 15:27
- Visual Basic(VBA) vbaエクセルマクロ RemoveDuplicatesについて RemoveDuplicatesを使 3 2023/02/28 01:13
- Excel(エクセル) excelで検索した商品の画像(ネットワーク上の)を表示させたい。 3 2023/06/28 00:32
- Visual Basic(VBA) 【VBA】指定した検索条件に一致したら別シートに転記したい 2 2022/03/23 16:14
- Excel(エクセル) VBAで同フォルダ内の別ブックを開かず参照して条件の一致する行の指定セルを抽出するには? 1 2022/07/21 19:29
- Visual Basic(VBA) VBAで最新のデータを別シートに転記する方法をお教えください。 3 2022/04/07 19:20
- Excel(エクセル) 【困っています】VBA 追加処理の記述を教えてください。 1 2022/08/25 22:54
このQ&Aを見た人はこんなQ&Aも見ています
-
好きなおでんの具材ドラフト会議しましょう
肌寒くなってきて、温かい食べ物がおいしい季節になってきましたね。 みなさんはおでんの具材でひとつ選ぶなら何にしますか? 1番好きなおでんの具材を教えてください。
-
あなたにとってのゴールデンタイムはいつですか?
一週間の中でもっともテンションが上がる「ゴールデンタイム」はいつですか? その逆で、一週間でもっとも落ち込むタイミングでも構いません。 よかったら教えて下さい!
-
初めて自分の家と他人の家が違う、と意識した時
子供の頃、友達の家に行くと「なんか自分の家と匂いが違うな?」って思いませんでしたか?
-
いけず言葉しりとり
はんなりと心にダメージを与える「いけず言葉」でしりとりをしましょう。 「あ」あら〜しゃれた服着てはりますな 遠くからでもわかりましたわ
-
お風呂の温度、何℃にしてますか?
みなさん、家のお風呂って何℃で入ってますか? ぬるめのお湯にゆったり…という方もいれば、熱いのが好き!という方もいるかと思います。 我が家は平均的(?)な42℃設定なのですが、みなさんのご家庭では何℃に設定していますか?
-
VBA 別シートの同じ日付の欄に値を貼付け
Excel(エクセル)
-
エクセルのVBAで日付を検索し転機したい
Visual Basic(VBA)
-
excel vbaで日付一致の行にデータ転記
Excel(エクセル)
-
-
4
(VBAにて)日付でデータを抽出するやり方
Excel(エクセル)
-
5
実行時エラー 438になった時の対処法を教えて下さい。
Visual Basic(VBA)
-
6
A1セルに入力したら、入力時間をA2セルに自動挿入
Excel(エクセル)
-
7
ExcelVBAを使って、値がある場合は作業を繰り返し実行するプログラムを作成したい。
Visual Basic(VBA)
-
8
指定したセルと同じ日付の入ったセルを選択するVBA
その他(Microsoft Office)
-
9
エクセルマクロで不特定なファイル名を使用するには
Excel(エクセル)
-
10
TODAY()で設定したセルの日付が変わったらマクロを実施させたい
Visual Basic(VBA)
-
11
特定の複数のシートに同じ処理をさせたい
Excel(エクセル)
-
12
VBA 値と一致した行の一部の列のデータを転記について教えてください
Visual Basic(VBA)
-
13
実行時エラー 438 の解決策をおしえてください。
Visual Basic(VBA)
-
14
エクセル 違う表から同じ日付のデータを検索
Excel(エクセル)
-
15
VBA 日付一致で転記
Visual Basic(VBA)
-
16
VBA シート名が一致した場合の転記内容について
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ユーザーフォームに入力したデ...
-
特定の文字を含むシートだけマ...
-
excelのマクロで該当処理できな...
-
ブック名、シート名を他のモジ...
-
【ExcelVBA】全シートのセルの...
-
XL:BeforeDoubleClickが動かない
-
別のシートから値を取得するとき
-
VBA 存在しないシートを選...
-
【VBA】特定の文字で改行(次の...
-
Excelマクロのエラーを解決した...
-
実行時エラー'1004': WorkSheet...
-
ExcelのVBAのマクロで他のシー...
-
エクセル・マクロ シートの非...
-
VBAで指定シート以外の選択
-
VBA 検索して一致したセル...
-
シート削除のマクロで「delete...
-
VBA 最終行まで数式をコピーする
-
vbaでworksheetfunctionでの複...
-
エクセルのマクロでアクティブ...
-
エクセルのマクロについて教え...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
特定の文字を含むシートだけマ...
-
【ExcelVBA】全シートのセルの...
-
ユーザーフォームに入力したデ...
-
実行時エラー'1004': WorkSheet...
-
XL:BeforeDoubleClickが動かない
-
excelのマクロで該当処理できな...
-
Excelマクロのエラーを解決した...
-
別のシートから値を取得するとき
-
ブック名、シート名を他のモジ...
-
VBA 存在しないシートを選...
-
シートが保護されている状態で...
-
同じ作業を複数のシートに実行...
-
VBAで指定シート以外の選択
-
Excel VBA リンク先をシート...
-
エクセル・マクロ シートの非...
-
実行時エラー1004「Select メソ...
-
ExcelのVBAのマクロで他のシー...
-
【Excel VBA】Worksheets().Act...
-
エクセルVBA Ifでシート名が合...
-
userFormに貼り付けたLabelを変...
おすすめ情報
お世話になります。ご質問にお答えします。最初の回答が上手くできてないかもしれません。
>既に値のあるセル(月日と商品記号?)が次の作業で同じだった場合』はどのようになるのでしょう
複写先の管理表は、年度末の3月31日に貸出残高を4月1日の貸出にコピーした後、貸出と返却の数量を消去し、日付も更新、1年間使えるようにして同一ブックを継続使用します。
複写元のデータは日付、商品A,商品Bともに毎営業日データを更新します。数量が0や同じ場合もあります。
〉複写元のA列の値は『商品A』なのか『A』だけなのか
複写元A列の値(入力している情報)は「商品A]です。
めぐみん 様
お手数をお掛けします。
商品名とシート名の関係は、
商品Aは「千葉」でシート名は千4-6、千7-9、千10-12、千1-3
商品Bは「京葉」でシート名は京4-6、京7-9、京10-12、京1-3
漢字2文字の先頭文字を使ってシートを区別していますが、シート名については、商品名と期間を合わせた「千葉4-6」、「京葉4-6」でも全く構いません。
〉数日後に以前入れた日付にまた数値を入れる事があるのかないのか?
数量の入力は営業日毎に締め切りますので、過去に戻って同一日に2回目を入力することはありません。複写先のシートに予め作成したカレンダー(A列)から当日を検索して、B列にデータを入力するという作業です。
いかがでしょうか。申し訳ありません。
めぐみん 様
ありがとうございます。
複写先のBook2のシートについては、手作業で作成することを前提に、一覧表としての見易さを優先して合計8シートになっています。
最初からマクロ処理で自動化を前提にしておけば、もっと簡単なマクロコードになったのではないかと思い、それなら書式の変更も検討するつもりでしたが、「現状のシートの作り方であってもコード作成について言うなら難易度はさほど変わりません。」とのコメントをいただき、安心しました。
今回のコメントから、Book2のシートの書式は変更することなく使用したいと思います。職場で慣れた形ですから。
めぐみん 様
早速にありがとうございました。
ご教示いただいたコードで、千葉を処理できました。
ただし、データは指定の月日に複写されましたが、実行後にエラーが表示されます。
”インデックスが有効範囲にありません”
修正は箇所は Set ws = Workbooks("Book2.xlsx").Worksheets(rr.Value & v(mm))
となります。
book1(sheet1)のA2の名称は千葉
book2のシート名は、千葉4-6、千葉7-9、千葉10-12、千葉1-3 (月は半角)
拡張子は.xlsx
上記の設定では足りない箇所がありますでしょうか?
めぐみん 様
エラーの原因が分かりました。
book1(sheet1)のA2の名称は千葉ですが、A3に設定した京葉のシートを準備しないまま実行したことが原因でした。
全て上手く出来ました。