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も見ています
-
プロが教えるわが家の防犯対策術!
ホームセキュリティのプロが、家庭の防犯対策を真剣に考える 2組のご夫婦へ実際の防犯対策術をご紹介!どうすれば家と家族を守れるのかを教えます!
-
エクセルのマクロで結合セルに値を貼り付けたい
Excel(エクセル)
-
VBAでの結合セルのコピー&ペースト
Excel(エクセル)
-
VBAでブックを非表示で開いて処理して閉じる方法
Excel(エクセル)
-
-
4
Rangeメソッドは失敗しました。globalオブジェクトについて
Excel(エクセル)
-
5
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
6
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
7
excelで結合セルの場合にエラーが出てしまう
Visual Basic(VBA)
-
8
別のシートから値を取得するとき
Visual Basic(VBA)
-
9
VBA マクロ実行時エラー’1004RangeクラスのPasteSpecialメソッドが失敗
Access(アクセス)
-
10
マクロの「SaveAs」でエラーが出るのを解消したいです(再)
Visual Basic(VBA)
-
11
EXCEL VBA マクロ 実行する度に処理速度がどんどん遅くなる原因が知りたい
Excel(エクセル)
-
12
VBAでセル入力の数式に変数を用いたい
Excel(エクセル)
-
13
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
14
エクセルでエラーが出て困っています。
Excel(エクセル)
-
15
VBA シートのボタン名を変更したい
Visual Basic(VBA)
-
16
【Excel VBA】ネットワーク上の共有フォルダにあるExcelを開く
Excel(エクセル)
-
17
VBAで結合したセルがクリアできない
Excel(エクセル)
-
18
エクセルVBAが途中で止まります
Visual Basic(VBA)
-
19
エクセルVBAでセルに入力したパスでブックを開く
Excel(エクセル)
-
20
UserForm1.Showでエラーになります。
工学
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBAでの SendKeysの変数指定方法
-
Excel VBA:フォーム←→セルのア...
-
vbaで指定したセルより下の行を...
-
選択されたセルが赤くなる方法...
-
excel マクロでの特殊文字入力方法
-
ダブルクリックでセルに色をつ...
-
Excelのマクロで選択している行...
-
セルをクリックしたら色を変え...
-
マクロ:エクセルVBAでのワーク...
-
(エクセルVBA)セルを左クリッ...
-
写真貼り付けを3列で折り返したい
-
【マクロ】1つのセルから結合...
-
マクロのデータ削除
-
結合されたセルの移動 VBA
-
Excel VBA で色付きのセルの値...
-
Excel VBAでのWorksheet_Change...
-
電話番号の入力方式が違うデー...
-
VLOOKUPの列番号の最大は?
-
マクロの「SaveAs」でエラーが...
-
VBAで色の付いているセルの行削除
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
vbaで指定したセルより下の行を...
-
エクセルでセルをクリックする...
-
VBAでの SendKeysの変数指定方法
-
Excel VBA:フォーム←→セルのア...
-
Excelマクロ セルを行頭に移動
-
【VBA】アクティブセルだけ背景...
-
IF関数で違う値もTRUEになる
-
エクセルマクロで「セルのサイ...
-
Excel VBA で色付きのセルの値...
-
ダブルクリックでセルに色をつ...
-
excel マクロでの特殊文字入力方法
-
マクロのデータ削除
-
ExcelVBA コンボボックスに入力...
-
ファイルサーバー上のexcelファ...
-
VBA Rangeの足し算
-
(エクセルVBA)セルを左クリッ...
-
Excelのマクロで選択している行...
-
セルをクリックしたら色を変え...
-
エクセル:セルの色のコード番...
-
EXCEL(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のコード表やコードの意味などで調べてみましたが、分かりません。
今後の勉強のために教えていただけると助かります。
お願いします。