For~Next構文内でシートコピーしていると途中で、
実行時エラー'1004’
WorksheetクラスのCopyメソッドが失敗しました。
が表示されることがあります。

該当のFor~Next文は10回以上実行されているので、コードの誤りではないと思うのですが、なぜ「Copyメソッドが失敗」するのかわかりません。
理由/対処方法がわかればありがたいと思い質問させていただきます。

**該当コード**
Sub 評価シート作成()
  Sheets(社員一覧).Select
  行 = 1
  Do
    ReDim Preserve 社員CD(行)
    ReDim Preserve 氏名(行)
    社員CD(行) = Cells(行 + 1, 1).Value
    氏名(行) = Cells(行 + 1, 2).Value
    行 = 行 + 1
  Loop Until Cells(行, 1) = ""
  人数 = 行 - 2
  For 回数 = 1 To 人数
    Sheets(評価シート).Select
    Sheets(評価シート).Copy after:=Sheets(評価シート)
    ActiveSheet.Name = 氏名(回数)
    Cells(4, 5) = 氏名(回数)
    Cells(4, 3) = 社員CD(回数)
  Next 回数
End Sub
*****************************
よろしくお願いします

このQ&Aに関連する最新のQ&A

A 回答 (4件)

ひょっとしてこれに該当するのかな?



Excel でプログラムを使用してワークシートをコピーするとランタイム エラー 1004 が発生する
http://support.microsoft.com/kb/210684/ja

この回答への補足

URL参考になります。
テンプレートでの方法を試してみようと思います。

補足日時:2009/05/13 08:36
    • good
    • 6
この回答へのお礼

テンプレートでの方法で無事対応できました。

お礼日時:2009/05/13 11:32

こんにちは。



コードとしては、失礼ですが、動的配列を使いながら、2バイト文字変数では、ものすごくバランスが悪いです。申し訳ないのですが、私には、修正とかいうレベルではないです。2バイト文字の変数のオンパレードはミスの元です。動的配列を使いたい気持ちは分からないわけではないけれども、そのためには、もう少し、初歩的な技術の蓄積が必要ではないでしょうか。

もともと、そのコードでは動くわけないのでしょうから、掲示板に載せるために、相当に省いているのか加工しているのだと思います。

Sheets("評価シート").Copy after:=Sheets("評価シート")
"" のクォーテーションは、どうなっているのでしょうか?

ActiveSheet.Name = 氏名(回数)
これも、実にエラーが発生しやすいです。

それから、
For i = Rng.Rows.Count To 1 Step -1
左から順に入れていくなら、このように逆にしたほうがよいのではないでしょうか。これは一例です。


Sub EvaluationSheetMaking()
  Dim Sh1 As Worksheet
  Dim Sh2 As Worksheet
  Dim Rng As Range
  Dim i As Long
  
  Set Sh1 = Worksheets("社員一覧")
  Set Sh2 = Worksheets("評価シート")
  With Sh1
    Set Rng = .Range("A2", .Range("A65536").End(xlUp).Offset(, 1))
  End With
  
  For i = Rng.Rows.Count To 1 Step -1
    On Error Resume Next
    Sh2.Copy After:=Sh2
    With ActiveSheet
      .Name = Rng.Cells(i, 2).Value
      .Cells(4, 5) = Rng.Cells(i, 2).Value
      .Cells(4, 3) = Rng.Cells(i, 1).Value
    End With
    On Error GoTo 0
  Next i
  Set Rng = Nothing
End Sub
    • good
    • 1

http://oshiete1.goo.ne.jp/qa1822561.html
この辺が参考になるのかなー
    • good
    • 0

>   ActiveSheet.Name = 氏名(回数)


のところが怪しい気がするんですが
実際はどの行でストップしてますか?
コードの該当行が反転しているはずですが

シート名に設定しようとしたデータ:氏名(回数)が空っぽとかではない?

この回答への補足

Sheets(評価シート).Copy after:=Sheets(評価シート で停止します。
何度か実行していますが同じ行数のところで失敗になります。
そうなるとワークシートから手作業でシートコピーしようとしてもできません。

一旦エクセルを終了→エクセルのみ再起動し、(シート名が重ならないよう)データを入替えて実行すれば、その前より少ない行数で失敗します。

なぜなのか見当もつきません。

補足日時:2009/05/12 15:11
    • good
    • 0

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!

このQ&Aを見た人はこんなQ&Aも見ています

このQ&Aを見た人が検索しているワード

このQ&Aと関連する良く見られている質問

QEXCEL VBA シートをコピーする時にエラーが発生してしまう件

EXCEL VBAでシートをコピーするマクロを作成しているのですが、【10】にて時々エラーが発生してしまいます。100シート分ぐらいをコピーしたいのですが、途中で30シートぐらいの所で止まってしまいます。
(シートが10前後だと問題なく処理が終ります)
止まってしまうシートはまちまちなので、
シート名称が問題だとは考えにくいです。

ちなみに【8】でのsheets_nameは取得できてます。
前後に何かを入れることにより解決するのか、
ソース本体をいじれば解決するのか、

詳しい方、何卒、解決方法を
ご指導いただけますよう宜しくお願いします。

【1】 '取得した配列の数だけループを行う。
【2】 For i = LBound(test) To 配列数 - 1
【3】
【4】 列番号 = Mid(test(i), 4, 3)
【5】 Debug.Print "test(" & i; ") : " & test(i)

【6】
【7】 'FORMATシートをコピーし、その名称を変数名にする
【8】 sheets_name = Worksheets("実績").Cells(18, 列番号).Value
【9】
【10】 Worksheets("FORMAT").Copy After:=Sheets("FORMAT")
【11】
【12】 ActiveSheet.Name = (sheets_name)
【13】 Cells(4, 3) = (sheets_name)

EXCEL VBAでシートをコピーするマクロを作成しているのですが、【10】にて時々エラーが発生してしまいます。100シート分ぐらいをコピーしたいのですが、途中で30シートぐらいの所で止まってしまいます。
(シートが10前後だと問題なく処理が終ります)
止まってしまうシートはまちまちなので、
シート名称が問題だとは考えにくいです。

ちなみに【8】でのsheets_nameは取得できてます。
前後に何かを入れることにより解決するのか、
ソース本体をいじれば解決するのか、

詳しい方、何卒、解決方法を
...続きを読む

Aベストアンサー

コードとしては下記と等価だと思います。
空のシートでやってみると、スムーズにうまく行きました。
下記のシートSheet1のデータ・関数式他メモリの使用状況によるのではないでしょうか。
コピーの終了を見届けて、次のループに入ればよいのかもしれませんが、可能か、どうすればよいか方法が私にはわかりません。
Sub test02()
For i = 1 To 100
sheets_name = i
Worksheets("Sheet1").Copy After:=Sheets("sheet1")
ActiveSheet.Name = sheets_name
Next i
End Sub
エクセル2002でXP標準メモリ容量程度です。

QVBA 実行時エラー1004 rangeメソッドは失敗しました。globalオブジェクトのエラー

始めまして、VBA初心者のものです。
ただいまエクセルでグラフを作成しています。作業自体は単純作業の繰り返しなのでVBAを用いてやりたいのですが、マクロを実行したときに実行時エラー’1004’rangeメソッドは失敗しました。’_global’オブジェクトとメッセージが出て、実行できません。 デバックをすると以下の5行目で黄色のバーが出ていました。自分なりに原因を考えたのですがrangeの関係するところに、Range("A8:A1587,e8:e1587")というような変数を用いないやり方でやると上手くいくので、変数に関する定義がまずいと思うのですが、それ以上の事は分かりません。どなたか、分かる方がおりましたら、よろしくお願いします。また、プログラムは以下のようになります。

Sub 繰り返し()
'繰り返し
Dim s As Integer
For s = 0 To 17
Range("cells(8,1):cells(1580,1),cells(8,s+2):cells(1580,s+2)").Select
Range("cells(8,s+2)").Activate
Charts.Add
ActiveChart.ChartType = xlXYScatter
ActiveChart.SetSourceData Source:=Sheets("20081216_210647").Range( _
"cells(8,1):cells(1580,1),cells(8,s+2):cells(1580,s+2)"), PlotBy:=xlColumns
ActiveChart.SeriesCollection(1).Name = "=""0810p2x"""
ActiveChart.Location Where:=xlLocationAsNewSheet, Name:="0810p2x"
With ActiveChart
.HasTitle = True
.ChartTitle.Characters.Text = "0810p2x"
.Axes(xlCategory, xlPrimary).HasTitle = True
.Axes(xlCategory, xlPrimary).AxisTitle.Characters.Text = "t"
.Axes(xlValue, xlPrimary).HasTitle = False
End With
Next
End Sub

始めまして、VBA初心者のものです。
ただいまエクセルでグラフを作成しています。作業自体は単純作業の繰り返しなのでVBAを用いてやりたいのですが、マクロを実行したときに実行時エラー’1004’rangeメソッドは失敗しました。’_global’オブジェクトとメッセージが出て、実行できません。 デバックをすると以下の5行目で黄色のバーが出ていました。自分なりに原因を考えたのですがrangeの関係するところに、Range("A8:A1587,e8:e1587")というような変数を用いないやり方でやると上手くいくので、変数に関する定義...続きを読む

Aベストアンサー

>ご指摘を受けたところを書き換えて回してみた結果、書き換えた箇所
>でエラーがでます。(実行時エラー’1004’’cells’メソッドは失敗
>しました。’global’オブジェクト)
>しかし、何が原因でエラーになるか自分では分かりません。

≪例1≫
Range(Cells(8, 1), Cells(1587, 2)).Select
上記の例では、RangeとかCellsの上位オブジェクトであるシート名が省略されています。
ActiveSheet.Range(ActiveSheet.Cells(8, 1), ActiveSheet.Cells(1587, 2)).Select
というわけです。
マクロ実行時に、Activeな(Excelで表示されている)シートが上位オブジェクトとして、自動的に認識されます。

≪例2≫
Sheets("Sheet2").Range(Cells(8, 1), Cells(1587, 2)).Select
上記の例では、Rangeのみシート名が記述されています。
Sheets("Sheet2").Range(ActiveSheet.Cells(8, 1), ActiveSheet.Cells(1587, 2)).Select
というわけです。
Activeなシートが、Sheet2の場合はエラーになりません。
しかし、ActiveなシートがSheet2以外の場合、エラーが発生します。
直前に、
Sheets("Sheet1").Select
などとしていれば、ActiveシートがSheet1になっていますから、エラーになります。

Sheets("Sheet2").Range(Sheets("Sheet2").Cells(8, 1), Sheets("Sheet2").Cells(1587, 2)).Select
と書いておけば安心です。
Withステートメントを使えばスッキリ纏めることができます。
With Sheets("Sheet2")
  .Range(.Cells(8, 1), .Cells(1587, 2)).Select
End With

# Sheets("Sheet2")の上位オブジェクトが省略されていることにも気がついてください。

>そこで自分で基礎を勉強したいのですが推薦できる参考書などがござ
>いましたら、教えていただけませんか?
私自身は、入門書程度の雑誌を1冊買っただけです。どれが良いとかはよく分かりません。
「マクロの記録」を活用して、参考コードを取得し、汎用性のあるコードに編集しています。
新しい単語があれば、文字カーソルを単語の上に置き、F1キーを押してVBAのヘルプを必ず見るようにしています。
躓いた時は、Web検索して欲しい情報を得たり、あるいは、こうした掲示板で先輩方のお力をお借りしています。

Excel(エクセル)VBA入門:目次
http://oshiete1.goo.ne.jp/kotaeru_reply.php3?q=4651404
エクセル入門・初級編
http://www.kenzo30.com/excel_kiso.htm

>ご指摘を受けたところを書き換えて回してみた結果、書き換えた箇所
>でエラーがでます。(実行時エラー’1004’’cells’メソッドは失敗
>しました。’global’オブジェクト)
>しかし、何が原因でエラーになるか自分では分かりません。

≪例1≫
Range(Cells(8, 1), Cells(1587, 2)).Select
上記の例では、RangeとかCellsの上位オブジェクトであるシート名が省略されています。
ActiveSheet.Range(ActiveSheet.Cells(8, 1), ActiveSheet.Cells(1587, 2)).Select
というわけです。
マクロ実行時に、Activeな...続きを読む

QEXCEL VBA で現在開いているブックのファイル名を取得する方法

EXCEL2003 VBAで業務を簡素化するために、現在開いているブックのファイル名を取得する方法が分かりません。
作業手順をマクロを使って処理していますが、オリジナルのワークブックをファイル名を変えて保存し、以後、このワークブックを読み込んで使用しています。
このときのVBAは、オリジナルのファイル名を使っているため、ファイル名を変更するとエラーになり、以後の業務に使用できません。
常にファイル名を取得出来るVBAをどなたか、教えて下さい。

Aベストアンサー

>現在開いているブックのファイル名
 ちょっと曖昧な表現かなぁという気もいたしますが、VBAが書いてあるブックのブック名は
ThisWorkbook.Name
で、現在 "アクティブにして" 操作対象になっているブックの名前は
ActiveWorkbook.Name
ですね。

 しかし、
>VBAは、オリジナルのファイル名を使っているため、ファイル名を変更するとエラーになり
というような文脈からすると、
ThisWorkbook.Name
の方ですかね。

QExel VBA 別ブックから該当データを検索し、必要なデータを取得する方法について

部品表というブックがあります
A列に商品名、B列に商品番号が入力してあります。C列のコードは未入力です。
A列     B列     C列      
商品名  商品番号  コード
モータ  U-1325-L  
ホルダ  R-134256

また、コード一覧表という別のブックには、A列に商品番号と、B列にコードが、何千件も入力されています。

やりたいことは
部品表のC列のコード欄に、コード一覧表ブックから商品番号と一致するコードを貼り付けしたいのです。

部品表は、何百種類もありますので、関数ではなく、マクロで処理を希望します。

自分では、部品表の商品番号をコピーして、コード一覧表で検索し、検索結果の右隣のセル(B列のコード)の値を部品表のC列に貼り付ければよいかと思い、書いてみたんですが…

Sub 別ブックから貼り付ける()
  Dim 検索する As Long
Windows("部品表.xls").Activate
検索する = cells(i,2).Value
Windows("コード一覧表.xls").Activate
ActiveWindow.SmallScroll Down:=-3
Selection.AutoFilter Field:=3, Criteria1:="=検索する", Operator:= xlAnd

と、してみたものの、検索しても、その検索結果の隣のセルのコードをどうやって取得すればいいのかが、わかりませんでした。

基本事項は本で学びましたが、呪文のようなコードはよく理解できません。懸命にネットで検索して、訳して理解する努力をしてはいますが。

どうぞよろしくお願いします。

部品表というブックがあります
A列に商品名、B列に商品番号が入力してあります。C列のコードは未入力です。
A列     B列     C列      
商品名  商品番号  コード
モータ  U-1325-L  
ホルダ  R-134256

また、コード一覧表という別のブックには、A列に商品番号と、B列にコードが、何千件も入力されています。

やりたいことは
部品表のC列のコード欄に、コード一覧表ブックから商品番号と一致するコードを貼り付けしたいのです。

部品表は、何百種類もありますので、関数...続きを読む

Aベストアンサー

こんにちは。
とりあえず実用性も踏まえました。
メインの動作はワークシート関数のVLOOKUPをVBA上で使用していますので理解はしやすいかと思います。
また、質問文から察するに「部品表.xls」と「コード一覧表.xls」の両方を開いて処理されていますが「コード一覧表.xls」はプログラム内で開いて閉じているので実行するときは「コード一覧表.xls」は閉じて置いてください。
Option Explicit
Sub Sample()
 Application.ScreenUpdating = False
 Dim I As Long
 Dim xlBook
 Set xlBook = Workbooks.Open("C:\★★\コード一覧表.xls") '★要変更★
 I = 2
 Do While Range("A" & I).Value <> ""
  ThisWorkbook.Worksheets("Sheet1").Range("C" & I).Value = Application.VLookup(ThisWorkbook.Worksheets("Sheet1").Range("B" & I).Value, xlBook.Worksheets("Sheet1").Range("A2:B65535"), 2, 0)
  I = I + 1
 Loop
 xlBook.Close
 Application.ScreenUpdating = True
 MsgBox ("完了")
End Sub

こんにちは。
とりあえず実用性も踏まえました。
メインの動作はワークシート関数のVLOOKUPをVBA上で使用していますので理解はしやすいかと思います。
また、質問文から察するに「部品表.xls」と「コード一覧表.xls」の両方を開いて処理されていますが「コード一覧表.xls」はプログラム内で開いて閉じているので実行するときは「コード一覧表.xls」は閉じて置いてください。
Option Explicit
Sub Sample()
 Application.ScreenUpdating = False
 Dim I As Long
 Dim xlBook
 Set xlBook = Workbooks....続きを読む

Qマクロ初心者です 実行時エラー1004 の解決方法を教えてください

マクロ初心者です
仕事で使っていたエクセルのマクロにエラーが出てしまいました。

「実行時エラー1004アプリケーション定義またはオブジェクト定義のエラーです。」

os:win2000

x = 0
y = 1
w_prv = "*"
Do While rc.EOF = False
If w_prv = "*" Or w_prv <> rc.Fields("種別名") Then
If w_prv <> "*" Then
NewSheet.Cells(y, x).FormulaR1C1 = "=SUM(RC[" & (2 - x) & "]:RC[-1])"
End If
y = y + 1
x = 2
End If
If y = 2 Then
NewSheet.Cells(1, x) = rc.Fields("所属名")
End If
If x = 2 Then
NewSheet.Cells(y, 1) = rc.Fields("種別名")
End If

NewSheet.Cells(y, x) = rc.Fields("数量計")
x = x + 1
w_prv = rc.Fields("種別名")
rc.MoveNext
Loop

NewSheet.Cells(y, x).FormulaR1C1 = "=SUM(RC[" & (2 - x) & "]:RC[-1])"

y = y + 1

For i = 2 To x
NewSheet.Cells(y, i).FormulaR1C1 = "=SUM(R[" & (2 - y) & "]C:R[-1]C)"
Next

NewSheet.Cells(1, x) = "合計"
NewSheet.Cells(y, 1) = "合計"

rc.Close

Call closeDB

End Sub

**************************************************

NewSheet.Cells(y, x).FormulaR1C1 = "=SUM(RC[" & (2 - x) & "]:RC[-1])"

ここでエラーが出ているみたいです。
エクセルのマクロで入力したデータをアクセスに落としそこから新しいシートで月ごとの統計をとれるようになっていたのですが、とれなくなってしまいました。

こんな説明でお分かりになりますでしょうか?
まったくの初心者なので…
よろしくお願いいたします。

マクロ初心者です
仕事で使っていたエクセルのマクロにエラーが出てしまいました。

「実行時エラー1004アプリケーション定義またはオブジェクト定義のエラーです。」

os:win2000

x = 0
y = 1
w_prv = "*"
Do While rc.EOF = False
If w_prv = "*" Or w_prv <> rc.Fields("種別名") Then
If w_prv <> "*" Then
NewSheet.Cells(y, x).FormulaR1C1 = "=SUM(RC[" & (2 - x) & "]:RC[-1])"
End If
y = y + 1
...続きを読む

Aベストアンサー

こんにちは。

内容はわかるけれども、途中からというのはどうも、あまり質問としては良くないですね。一応、ある程度、答えが必要なら、他人にわからせるためのコードは提供してもらいたいなって思います。

まったくの初心者が、ADO オブジェクトを使うというのも、少し無理があるとは思いますし、

>エクセルのマクロで入力したデータをアクセスに落としそこから新しいシートで月ごとの統計をとれるようになっていたのですが、とれなくなってしまいました。

とれなくなってしまったという、根本的な原因とか、それはわかりませんが、それらの数式に、全部、「'(シングルクォーテーション)」を入れたらどうでしょうか?しかし、そのままでは、文字列ですから、「=」の数式の入ったところは、少し遅くなるけれど、以下のように変えてみたらどうでしょうか?



NewSheet.Cells(y, x).FormulaR1C1 = "=SUM(RC[" & (2 - x) & "]:RC[-1])"
y = y + 1
For i = 2 To x
NewSheet.Cells(y, i).FormulaR1C1 = "=SUM(R[" & (2 - y) & "]C:R[-1]C)"
Next

      ↓
'-----------------------------------

With NewSheet
 .Cells(y, x).FormulaR1C1 = "'=SUM(RC[" & (2 - x) & "]:RC[-1])"
 .Cells(y, x).Value = .Cells(y, x).Value '(たぶん必要)
y = y + 1
For i = 2 To x
  .Cells(y, i).FormulaR1C1 = "'=SUM(R[" & (2 - y) & "]C:R[-1]C)"
  .Cells(y, i).Value = .Cells(y, i).Value '(たぶん必要)
Next
End With

'-----------------------------------

こんにちは。

内容はわかるけれども、途中からというのはどうも、あまり質問としては良くないですね。一応、ある程度、答えが必要なら、他人にわからせるためのコードは提供してもらいたいなって思います。

まったくの初心者が、ADO オブジェクトを使うというのも、少し無理があるとは思いますし、

>エクセルのマクロで入力したデータをアクセスに落としそこから新しいシートで月ごとの統計をとれるようになっていたのですが、とれなくなってしまいました。

とれなくなってしまったという、根本的な原...続きを読む

Qエクセルでコピーができなくなる

ワークシートが増えるように組んだのですが、
増やす数が多いと(25枚くらい)copyのところでひっかかってしまいます。
少ないと正常に動くのですが、それも例えば3枚増やすのを10回繰り返すと同じ現象でcopyできません。
いま、シートを3枚固定して4枚目以降を増やすようにしています。また、次に実行するときには4枚目以降を削除してから増やすように作ってあります。
ワークシートは255枚まで増やせるのでは?と思っていますが。

Aベストアンサー

追加です。
>シート2に40字弱の別ブックの表へのリンク式を80行30列記入した状態だと54枚程度

の状態で、コードを下記のように変更すると、300枚以上のシートの作成が可能になりました。
この方が使用メモリが押さえられるようです。

'シートのコピー
n = Worksheets(1).Range("a1")
i = 1
Worksheets(2).Cells.Copy
Do While i < n
i = i + 1
Sheets.Add after:=Worksheets(Worksheets.Count)
Worksheets(Worksheets.Count).Paste
Range("a2") = i
Loop

QEXCEL VBAマクロ作成で、他のEXCELからデータを取り込みたい

メインプログラム(EXCEL VBA)より、
他のフォルダーにあるEXCELの項目の内容を取り込みたいです。
たとえば他のフォルダーのEXCELのRange("A2:A3").ValueをメインプログラムのRange("C2:C3").Valueにセットしたい時です。

・コマンドボタン押したら、どこのEXCELから取り込むかのポップアップ(?)は、表示はできてます。
・作業者が選んだパスとブックもMsgBoxで表示できてるので、もらう相手の場所も取得できてます。

・となると次はOPEN,INPUTですか?
テキストデータの取り込みですと、Inputでそのバッファを定義してるのですが、なんか違うような。。。

よろしくお願いします!

Aベストアンサー

私がやる方法です。

Dim writeSheet As Worksheet ' 自分自身の書き出し先シート
Set writeSheet = ThisWorkbook.Worksheets(1) ' Sheet1 を参照

Dim readBook As Workbook ' 相手ブック
Set readBook = Workbooks.Open(filename) ' 相手ブックを開いて参照
Dim readSheet As WorkSheet ' 相手シート
Set readSheet = readBook.Worksheets("sheetName") ' 相手シートを参照
' または Set readSheet = readBook.Worksheets(sheetIndex)

' 例えば
writeSheet.Cells(1, 1).Value = readSheet.Cells(2, 2).Value ' 相手シートの B2 の値を自分自身の A1 に書き込む

readBook.Close False ' 相手ブックを閉じる
Set readSheet = Nothing
Set readBook = Nothing

私がやる方法です。

Dim writeSheet As Worksheet ' 自分自身の書き出し先シート
Set writeSheet = ThisWorkbook.Worksheets(1) ' Sheet1 を参照

Dim readBook As Workbook ' 相手ブック
Set readBook = Workbooks.Open(filename) ' 相手ブックを開いて参照
Dim readSheet As WorkSheet ' 相手シート
Set readSheet = readBook.Worksheets("sheetName") ' 相手シートを参照
' または Set readSheet = readBook.Worksheets(sheetIndex)

' 例えば
writeSheet.Cells(1, 1).Value = readSheet.Ce...続きを読む

Q別のシートから値を取得するとき

Worksheets("シート名").Activate
上記のを行ってから別シートの値を取得するのですが、
この処理を行うと指定したシートへ強制的にとんでしまいます。。。

※イメージ
For ~ To ~
  Worksheets("シートA").Activate
  シートAの値取得
       :
  Worksheets("シートB").Activate
  シートBの値取得
Next

このイメージ処理を行うとものすごい勢いで画面がチカチカします。。。
シートを変えずに他のシートから値を取得する方法はないのでしょうか。
教えてください!

Aベストアンサー

Worksheets("シートA").Range("A1")

みたいな感じでできませんか?

QVBAにて実行時エラー’1004’:「アプリケーション定義又はオブジェクト定義のエラー」発生?

VBA初心者です。Xp,Excel2000を使用しています。
シフト者のカレンダー作成しており、動作していたVBAのコピーを利用しています。
何回かループを回った後表記エラーとなります。アドバイスをお願いいたします。

  A B C D E
--------------------------
1 2 3 4 ...... <-- 日付
2 2 0 1 ...... <-- シフト(ln_1の範囲名)
7 8 9 10 ...... <-- 日付
1 0 3 3 ..... <-- シフト(ln_2の範囲名)
....................

For i = 1 To 6   <-- 最大6週にわたる
Set r = Range("ln_" & LTrim$(Str$(i)))
cpos = r.Column
rpos = r.Row
For n = 1 To r.Columns.Count
With Cells(rpos - 1, cpos + n - 1)
m = .Characters.Count <-- 数回ループ後ここでエラーとなる!
s = Cells(rpos, cpos + n - 1) <-- シフト情報
Select Case s
Case ""    '- Blank -
........ 日付セルの装飾

Case "0" '- Holiday -
......... 日付セルの装飾

Case "1" '- shift1 -
........... 日付セルの装飾

VBA初心者です。Xp,Excel2000を使用しています。
シフト者のカレンダー作成しており、動作していたVBAのコピーを利用しています。
何回かループを回った後表記エラーとなります。アドバイスをお願いいたします。

  A B C D E
--------------------------
1 2 3 4 ...... <-- 日付
2 2 0 1 ...... <-- シフト(ln_1の範囲名)
7 8 9 10 ...... <-- 日付
1 0 3 3 ..... <-- シフト(ln_2の範囲名...続きを読む

Aベストアンサー

よく調べてみたら、Characters.Countは、"ABC"などの文字列では3を返しますが、"123"ではエラーになり、数字ではだめなようです。セルの書式を文字列にしてもだめでした。

m = .Characters.Count は文字の数をお知りになりたいだけのようなので、以下のコードに換えて試してみてください。

m=Len(.value)

なお、MsgBox .Address などは、エラーのでるコードの前に挿入、という意味で書きました。
泥臭い方法ですが、コードがどのセルを参照しているのかわかるので、エラーがでる時などにはおすすめです。

QExcel2003でworksheetクラスのCopyメソッドが失敗し

Excel2003でworksheetクラスのCopyメソッドが失敗しました。
という表示がでて全く原因がわからず困っています。
詳細は

ThisWorkbook.Worksheets("請求書・原本").Copy Before:=Worksheets(sheetname2)

の箇所でエラーが発生します。
発生する場所はたまに変わります。
すぐ上のプロシージャで実行している同じようなステートメントは問題なく実行されるのですが、
急に同じ構文の箇所で発生しているので全く理由がわかりません。
変数で設定しているシート名は確実に存在しています。

コードは以下のとおりです。

Function fncPrtCon2(ByVal sheetname As String, ByVal siki As String, ByVal mainScr As String, ByVal i As Long)

'【変数】
Dim wDate As Date '日付入力用変数
Dim xDate As Date
Dim work As String '日付フォーマット用
Dim sheetname2 As String



ThisWorkbook.Worksheets("明細・原本").Copy Before:=Worksheets("明細・原本")
sheetname = sheetname & "・" & Worksheets(mainScr).Cells(i + 1, 6).Value & "・明細"
ActiveSheet.Name = sheetname
sheetname2 = sheetname

(中略)

  '原本シートコピー
ThisWorkbook.Worksheets("請求書・原本").Copy Before:=Worksheets(sheetname2)
sheetname = Replace(sheetname, "・明細", "")
ActiveSheet.Name = sheetname

End Function

上記コードはサブモジュールでメインから各引数を値渡ししています。
Copyメソッドの引数を省略して実行すると成功します。
どこか問題のある箇所があるでしょうか。
助言お願いします。

Excel2003でworksheetクラスのCopyメソッドが失敗しました。
という表示がでて全く原因がわからず困っています。
詳細は

ThisWorkbook.Worksheets("請求書・原本").Copy Before:=Worksheets(sheetname2)

の箇所でエラーが発生します。
発生する場所はたまに変わります。
すぐ上のプロシージャで実行している同じようなステートメントは問題なく実行されるのですが、
急に同じ構文の箇所で発生しているので全く理由がわかりません。
変数で設定しているシート名は確実に存在しています。

コードは以下のとおりで...続きを読む

Aベストアンサー

>エラーが発生します。
これだけでは、いろいろな事が考えられるので、憶測でしか物を言えません。
エラーが出ているときは、エラーメッセージも載せるようにしましょうね。


引数のBefore:=Worksheets(sheetname2)

このシート「Worksheets(sheetname2)」は、アクティブなワークブックに存在しているシートではないとか?

Before:=Workbooks("Book1.xlsなどのブック名").Worksheets(sheetname2)
という感じにしてあげるとうまくいくかもしれません。


このQ&Aを見た人がよく見るQ&A

人気Q&Aランキング

おすすめ情報