
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も見ています
-
プロが教える店舗&オフィスのセキュリティ対策術
中・小規模の店舗やオフィスのセキュリティセキュリティ対策について、プロにどう対策すべきか 何を注意すべきかを教えていただきました!
-
VBAでの結合セルのコピー&ペースト
Excel(エクセル)
-
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
excelで結合セルの場合にエラーが出てしまう
Visual Basic(VBA)
-
-
4
エクセルのマクロで結合セルに値を貼り付けたい
Excel(エクセル)
-
5
実行時エラー1004について
Excel(エクセル)
-
6
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
7
VBAでループ内で使う変数名を可変にできないか。
Visual Basic(VBA)
-
8
ExcelVBAを使って、値がある場合は作業を繰り返し実行するプログラムを作成したい。
Visual Basic(VBA)
-
9
EXCEL VBA セルに既に入力されている文字に文字を追加する
Excel(エクセル)
-
10
Excelで重複データの件数ではなく、何番目かを求める方法
Excel(エクセル)
-
11
エクセルマクロで特定の範囲が空白という条件
Excel(エクセル)
-
12
VBA 半角スペースを入れるには...
その他(Microsoft Office)
-
13
エクセル マクロ オートフィルの終点の指定について
Excel(エクセル)
-
14
結合したセルの並び替え(エクセルVBA)
Excel(エクセル)
-
15
VBAで別モジュールへの変数の受け渡し方法
Visual Basic(VBA)
-
16
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
17
Rangeメソッドは失敗しました。globalオブジェクトについて
Excel(エクセル)
-
18
Excelの条件付き書式設定の太い罫線
Excel(エクセル)
-
19
VBAコード記述に際して、コード全体を自動的にインデント付ける方法
Access(アクセス)
-
20
エクセル ファイルを削除できないようにしたいです
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
人気Q&Aランキング
-
4
ダブルクリックでセルに色をつ...
-
5
EXCEL(VBA) セルをクリックし...
-
6
ExcelVBA コンボボックスに入力...
-
7
excel マクロでの特殊文字入力方法
-
8
VBAでの SendKeysの変数指定方法
-
9
vbaで指定したセルより下の行を...
-
10
VBAを使って検索したセルをコピ...
-
11
[EXCEL]ボタン押す→時刻が表に...
-
12
Excel VBAでのWorksheet_Change...
-
13
【エクセル】フリーワード検索...
-
14
【Excel関数】UNIQUE関数で"0"...
-
15
空白セルをとばして転記
-
16
Excelで、あるセルの値に応じて...
-
17
EXCELのSheet番号って変更でき...
-
18
VLOOKUPの列番号の最大は?
-
19
別ブックをダイアログボックス...
-
20
VBA
おすすめ情報
公式facebook
公式twitter
エラー部分の黄色で表示されているのは、
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のコード表やコードの意味などで調べてみましたが、分かりません。
今後の勉強のために教えていただけると助かります。
お願いします。