
Excel2007で作った97-2003形式の請求書ファイルを使っています。自分でマクロを使って作っているのですが、今回エラーがでて、マクロが動かずに困っています。
エラーの内容は、
『実行時エラー 1004:
この操作を行うには、すべての結合セルを同じサイズにする必要があります。』
というものです。
デバッグをクリックすると、添付画像の様に、請求書sheetの備考欄に貼付け処理を指示した部分がマーキングされています。
このファイルは6sheetあり、1枚目の入力sheetから、2枚目の売上帳sheet・3枚目の請求書sheetに入力内容がコピペで飛ぶように作っています。マクロの内容は主にコピペです。
ここで分からないのが、2枚目の売上帳sheetには問題なく、3枚目の請求書sheetに飛ばそうとすると上記のエラー表示が出て止まります。
試しに請求書sheetの結合したセルを全解除してマクロを起動させるとエラーは出ませんでした。
売上帳sheetにはマクロ操作での転記部分に結合セルはなく(同sheet内には結合セルは存在する)、入力sheetには転記の元セルには結合セルが含まれています。請求書sheetには多数結合セルが混じり、転記部分にも結合セルは含まれています。やはり結合セルが原因でしょうか?
これまでいろいろなパソコンでExcel2007~2013までは問題なく動いていました。
OSもXPからVista、win8、win8.1、アップグレードしたwin10と昨年購入した初めからのwin10とすべて問題なく動いていました。
Excel2016のデメリットでしょうか?
何か対処法はないでしょうか?
原因が受けsheet側の結合セルだとすれば、マクロに関係する部分のセルの結合をすべて解いてやらなければならないのでしょうか?
他に良い案があれば教えてください。
パソコンに詳しくなく、すべて独学で質問サイトなどで助けていただきながらやってきているので、またまた困っています。
宜しくお願いします。

No.7ベストアンサー
- 回答日時:
Excelのヘルプでは、次のような説明になっているのですが、どうしてうまくいくのかはわかりません。
手動でいろいろ試していたら、これでうまくいっただけなんですよね。結果オーライですいません。xlPasteValues→値を貼り付けます
xlPasteValuesAndNumberFormats→値と数値の書式を貼り付けます。
そうだったんですか!
本当にお手数をかけさせてすみません!!
でも大変助かりました。
今のところは他に不具合なく動いています。
元々初心者の私が自分でソフトっぽく作ったファイルなので、バグが出ては改良して・・・、というのを繰り返して使っているので、今回も同じように使っていきます。
この度は本当にありがとうございました!
No.6
- 回答日時:
わたしはExcel2010を使っているのですが、補足して頂いた条件で実行してみたところ、同じエラーが出ました。
「Excel2007~2013までは問題なく動いていました」とのことですが、どうしてでしょうね?とりあえず原因は置いといて、解決策を模索してみました。
下記のようにすると一応は動いたのですが、もしかしたら他の部分に影響が出るかもしえません。その辺は自己責任でお願いします。
Paste:=xlPasteValues
↓
Paste:=xlPasteValuesAndNumberFormats
No.4
- 回答日時:
No1さんの要求通り、該当プロシージャ(Sub~End Subまで)を添付すべきです。
エラーが発生した行だけだと、難しいと思います。それから「請求書備考NO.1」の名前で参照しているセル範囲はどこになりますか?
すみません。プロシージャの意味が分かっておらず、該当行のみしか記載してませんでした。
補足に追加しました。
あと、「請求書備考NO.1」は請求書sheetのJ62とK62の結合セルです。
ここを起点に、10行分が転記されるようになっています。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) Sheet「状況」から、分類の年齢別カウント数をSheet「D表」へ転記する下記マクロを作っています 7 2022/12/14 17:57
- Excel(エクセル) Excel2019 マクロを使用し画像を貼り付けした際のリンク切れについて 2 2022/11/15 16:14
- その他(プログラミング・Web制作) python OpenPyXLを使って出力結果をエクセルに書き込み 2 2022/06/04 19:46
- Excel(エクセル) エクセルのマクロについて教えてください。 2 2023/02/26 13:19
- その他(Microsoft Office) 従業員増減対応で当番種類の増減対応な当番表 21 2022/07/19 07:30
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
- Excel(エクセル) Excelのマクロについてご教授ください 2 2023/02/25 09:43
- Visual Basic(VBA) Excelのマクロコードについて教えてください。 1 2022/03/27 13:25
- その他(プログラミング・Web制作) pythonでクラスで複数のメソッドを利用する方法 2 2022/04/15 04:17
- Excel(エクセル) VBAにてエクセルをpdf化する方法 1 2023/03/10 16:20
このQ&Aを見た人はこんなQ&Aも見ています
-
VBAでの結合セルのコピー&ペースト
Excel(エクセル)
-
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
VBAマクロ 実行時エラーが出たり出なかったり
Excel(エクセル)
-
-
4
数式による空白を無視して最終行を取得するマクロ
Excel(エクセル)
-
5
【VBA】特定の値が入った行をコピーして別シートに貼り付ける方法をおしえていただきたいです。
Excel(エクセル)
-
6
VBA マクロ実行時エラー’1004RangeクラスのPasteSpecialメソッドが失敗
Access(アクセス)
-
7
VBAのコマンドボタンの文字列の改行方法は?
Visual Basic(VBA)
-
8
エクセルのマクロで結合セルに値を貼り付けたい
Excel(エクセル)
-
9
Excel2003 マクロ 1ページのみ印刷する
Excel(エクセル)
-
10
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
11
ExcelのVBAでDisplayalertsで警告メッセージが非表示にできない
Excel(エクセル)
-
12
実行時エラー 438になった時の対処法を教えて下さい。
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
vbaで指定したセルより下の行を...
-
VBAでの SendKeysの変数指定方法
-
写真貼り付けを3列で折り返したい
-
エクセルでセルをクリックする...
-
Excelマクロ セルを行頭に移動
-
マクロを教えてください
-
【マクロ】1つのセルから結合...
-
excel マクロでの特殊文字入力方法
-
(エクセルVBA)セルを左クリッ...
-
VBA Rangeの足し算
-
セルをクリックしたら色を変え...
-
Excelで数値の変化をカウントし...
-
結合セル内の値を、結合解除後...
-
エクセル VBA アクティブセル...
-
「段」と「行」の違いがよくわ...
-
エクセルで離れた列を選択して...
-
チェックボックスをクリックし...
-
別ブックをダイアログボックス...
-
Excelで空白セル直前のセルデー...
-
vba 2つの条件が一致したら...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
vbaで指定したセルより下の行を...
-
エクセルでセルをクリックする...
-
VBAでの SendKeysの変数指定方法
-
Excel VBA:フォーム←→セルのア...
-
エクセルマクロで「セルのサイ...
-
Excelマクロ セルを行頭に移動
-
マクロのデータ削除
-
セルをクリックしたら色を変え...
-
IF関数で違う値もTRUEになる
-
Excel VBA で色付きのセルの値...
-
excel マクロでの特殊文字入力方法
-
【EXCEL-VBA】特定の値の入った...
-
(エクセルVBA)セルを左クリッ...
-
ロックされていないセル内をクリア
-
ダブルクリックでセルに色をつ...
-
ファイルサーバー上のexcelファ...
-
Excelでプルダウンからフィルタ...
-
VBA Rangeの足し算
-
【VBA】アクティブセルだけ背景...
-
ExcelVBA コンボボックスに入力...
おすすめ情報
エラー部分の黄色で表示されているのは、
Range("請求書備考NO.1").PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False '請求書NO.1を起点に値の貼り付け
と表示されています。
ママチャリさん、すみません。
質問の仕方がよく分かっておらず補足させていただきます。
Sub 請求内訳書備考1()
Worksheets("売上入力").Activate '売上入力シートをアクティブにする
Range("G8:G17").Copy '請求内訳書No.1への転記部分をコピー
Worksheets("請求書").Activate '請求書シートをアクティブにする
Range("請求書備考NO.1").PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False '請求書備考NO.1を起点に値の貼り付け
End Sub
です。
試してみました。
2010でも2016でもエラーは出ずにうまくいきました。
記載したプロシージャ以外に、あと三個(請求書備考2、請求書備考3、締め日)同じようなコピペのマクロがあったのですが、そちらも同じように直すと、問題なく動きました。
調べてみると、この4個はどれも貼り付け先が結合セルになっていました。
最後に教えていただきたいのですが、今回追記した「AndNumberFormats」にはどういう意味があるのでしょうか?
VBAのコード表やコードの意味などで調べてみましたが、分かりません。
今後の勉強のために教えていただけると助かります。
お願いします。