
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で質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
VBAでの結合セルのコピー&ペースト
Excel(エクセル)
-
VBAマクロ 実行時エラーが出たり出なかったり
Excel(エクセル)
-
-
4
数式による空白を無視して最終行を取得するマクロ
Excel(エクセル)
-
5
【VBA】特定の値が入った行をコピーして別シートに貼り付ける方法をおしえていただきたいです。
Excel(エクセル)
-
6
VBAのコマンドボタンの文字列の改行方法は?
Visual Basic(VBA)
-
7
エクセルのマクロで結合セルに値を貼り付けたい
Excel(エクセル)
-
8
VBA マクロ実行時エラー’1004RangeクラスのPasteSpecialメソッドが失敗
Access(アクセス)
-
9
Excel2003 マクロ 1ページのみ印刷する
Excel(エクセル)
-
10
UserForm1.Showでエラーになります。
工学
-
11
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excelで数値の変化をカウントし...
-
vbaで指定したセルより下の行を...
-
エクセルでスピンボタンとスク...
-
EXCEL VBA で西暦の下一桁でセ...
-
エクセルマクロで「セルのサイ...
-
ExcelVBA コンボボックスに入力...
-
マクロのデータ削除
-
EXCELに画像を貼り付けマクロの...
-
Excel VBA:フォーム←→セルのア...
-
Excelのマクロで選択している行...
-
Excel VBA で色付きのセルの値...
-
Excelマクロ セルを行頭に移動
-
【マクロ】実行時エラー '424':...
-
特定の文字がある行以外を削除...
-
vba マージエリアの行数を非表...
-
Cellsのかっこの中はどっちが行...
-
エクセルで離れた列を選択して...
-
Excel UserForm の表示位置
-
[EXCEL]ボタン押す→時刻が表に...
-
エクセル マクロ 範囲指定で...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
vbaで指定したセルより下の行を...
-
VBAでの SendKeysの変数指定方法
-
Excelマクロ セルを行頭に移動
-
エクセルでセルをクリックする...
-
マクロのデータ削除
-
Excel VBA:フォーム←→セルのア...
-
エクセルマクロで「セルのサイ...
-
(エクセルVBA)セルを左クリッ...
-
セルをクリックしたら色を変え...
-
excel マクロでの特殊文字入力方法
-
Excel VBA で色付きのセルの値...
-
VBA Rangeの足し算
-
IF関数で違う値もTRUEになる
-
【マクロ】1つのセルから結合...
-
ファイルサーバー上のexcelファ...
-
結合セル内の値を、結合解除後...
-
【EXCEL-VBA】特定の値の入った...
-
ロックされていないセル内をクリア
-
VBA ボタンをセルの右側に合わ...
-
ダブルクリックでセルに色をつ...
おすすめ情報
エラー部分の黄色で表示されているのは、
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のコード表やコードの意味などで調べてみましたが、分かりません。
今後の勉強のために教えていただけると助かります。
お願いします。