質問失礼いたします。
下記コードの
Worksheets.Add after:=Worksheets(Worksheets.Count)
で、シート貼り付け時に空のシートを追加しています。
このシートに関数の
=IF(INDEX(果物の!A:A,ROW())=INDEX(出荷!A:A,ROW()),"○","×")
を入れたいのですがどうすればよろしいでしょうか。
分かる方お教えください。宜しくお願い致します。
下記コードです。
Sub 検索()
Dim fn(10000) 'フォルダ内ファイル名
Dim sn(10000, 2) 'フォルダ内エクセルファイル名、シート名
Dim i As Long, j As Long, k As Long, x As Long
Dim myPath As String 'フォルダパス
Dim ext As String '拡張子検索変数
'フォルダの選択
With Application.FileDialog(msoFileDialogFolderPicker) 'ダイアログ表示
.Title = "フォルダを選択"
.AllowMultiSelect = False
If .Show = -1 Then
myPath = .SelectedItems(1) 'パス取得
Else
Exit Sub
End If
End With
Application.ScreenUpdating = False '画面更新非表示
'ファイル名の取得
fn(1) = Dir(myPath & "\", vbDirectory)
i = 1
Do
i = i + 1
fn(i) = Dir
Loop Until fn(i) = ""
'シート名の取得
x = 0
For j = 1 To i - 1
ext = Mid(fn(j), InStrRev(fn(j), ".") + 1, 3) '拡張子取得
'エクセルファイルの時実行
If ext = "xls" Then
Workbooks.Open Filename:=myPath & "\" & fn(j)
For k = 1 To Sheets.Count
sn(x, 1) = fn(j) 'エクセルファイル名取得
If InStr(Sheets(k).Name, Range("A1").Text) > 0 Then
sn(x, 2) = Sheets(k).Name 'シート名取得
x = x + 1
End If
Next k
ActiveWorkbook.Close
End If
Next j
'シート名一覧の作成
Columns("A:B").Select
Selection.ClearContents
Cells(2, 1) = "作業フォルダ"
Cells(3, 1) = myPath
Cells(4, 1) = "ファイル名"
Cells(4, 2) = "シート名"
x = 0
Do
Cells(x + 5, 1) = sn(x, 1)
Cells(x + 5, 2) = sn(x, 2)
x = x + 1
Loop Until sn(x, 1) = ""
Range("A1").Select
Application.ScreenUpdating = True '画面更新表示
MsgBox "完了しました"
End Sub
'シート名ダブルクリックすると実行
Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
Dim fn As String, bk As String, pth As String
Dim ptBk As Workbook, ptBk_pth As String
Dim myname As String
If Intersect(Target, Range("B5", Cells(Rows.Count, "B").End(xlUp))) Is Nothing Then Exit Sub
Cancel = True
pth = Range("A3").Value
bk = Target.Offset(, -1).Value
fn = Target.Value
ptBk_pth = Application.GetOpenFilename("Excelブック,*.xls?") 'コピー先のブック選択
If ptBk_pth = "False" Then Exit Sub 'キャンセル時終了
Application.ScreenUpdating = False '画面更新非表示
Set ptBk = Workbooks.Open(ptBk_pth)
With Workbooks.Open(pth & "\" & bk)
Application.EnableEvents = False 'イベントを抑止
.Sheets(fn).Copy Before:=ptBk.Sheets(1)
Application.EnableEvents = True
.Close savechanges:=False 'コピー元は保存せず閉じる
End With
myname = InputBox("シート名を入力してください", "シート名を入力")
If myname = "" Then
End
Else
ActiveSheet.Name = myname
End If
Worksheets.Add after:=Worksheets(Worksheets.Count) '一番右に空のsheetを追加
ptBk.Close savechanges:=True 'コピー先は保存し閉じる
Application.ScreenUpdating = True '画面更新表示
End Sub
No.1ベストアンサー
- 回答日時:
こんにちは。
マクロの記録で、その関数を設定すれば良いのでは?と思います。
出来上がったコードを見て、必要に応じて修正し、提示したマクロへ
それを組み込めばと思います。
因みに、同様に、シート追加、関数を入れるを繰り返されるのでしょうか?
例えば、既に関数の入っているシートを準備して、それを原紙として準備
しておき、必要な時に、そのシートをコピーするでは、ダメでしょうか?
原紙シートが邪魔なら、隠しておくとか。
(余り手間が掛かるなら、今のシートを追加&関数挿入の方が良いかも
知れませんが。)
返信遅くなり申し訳ありません。
便利な機能教えていただき、ありがとうございます!
マクロの記録よくわかっていなかったのですが、調べてやってみたところすぐできました。
すごい便利なものなんですね
活用していきたいと思います。助かりました!
>因みに、同様に、シート追加、関数を入れるを繰り返されるのでしょうか?
>必要な時に、そのシートをコピーするでは、ダメでしょうか?
何度もやります。ですので、そのたびにコピー貼り付けすると、時間かかってしまうのでマクロで、と考えています。
No.2
- 回答日時:
こんにちは
対象はActiveWorkBookでよいのでしょうか?
セル範囲に式を設定するには、
Range(対象範囲).FormulaLocal = "式"
で、まとめて関数式を設定できます。
例えば、ご提示の式をセルA1:A100に設定する場合なら、
Worksheets(Worksheets.Count).Range("A1:A100").FormulaLocal = _
"=IF(INDEX(果物の!A:A,ROW())=INDEX(出荷!A:A,ROW()),""○"",""×"")"
で、できると思います。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) excel vbaでvlooupの変数がわかりません。 7 2022/05/30 09:35
- Visual Basic(VBA) 【前回の続き続きです、ご教示ください】VBAの記述方法がわかりません。 2 2022/08/24 20:49
- Visual Basic(VBA) VBAのユーザーフォームのテキストボックスに入力制限をしたい 6 2022/11/15 08:28
- Visual Basic(VBA) いつもお世話になっております、VBAで教えて頂きたいのですが 2 2022/05/05 22:20
- Excel(エクセル) VBAについて 3 2022/06/19 18:19
- Visual Basic(VBA) 【Excel VBA】自動メール送信の機能追加 5 2022/09/29 12:53
- Visual Basic(VBA) 別シートから年齢別の件数をカウントしたいの続き 5 2023/01/24 00:16
- Visual Basic(VBA) InputBoxでキャンセルボタンを押したらファイル自体を閉じたい 3 2022/07/23 17:52
- Visual Basic(VBA) 【VBA】写真の貼り付けコードがうまく機能しません。 5 2022/09/01 18:43
- Excel(エクセル) Excel VBAどこが間違ってますか? 4 2023/07/17 10:04
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ユーザーフォームに入力したデ...
-
特定の文字を含むシートだけマ...
-
excelのマクロで該当処理できな...
-
ブック名、シート名を他のモジ...
-
【ExcelVBA】全シートのセルの...
-
XL:BeforeDoubleClickが動かない
-
別のシートから値を取得するとき
-
VBA 存在しないシートを選...
-
【VBA】特定の文字で改行(次の...
-
Excelマクロのエラーを解決した...
-
実行時エラー'1004': WorkSheet...
-
ExcelのVBAのマクロで他のシー...
-
エクセル・マクロ シートの非...
-
VBAで指定シート以外の選択
-
VBA 検索して一致したセル...
-
シート削除のマクロで「delete...
-
VBA 最終行まで数式をコピーする
-
vbaでworksheetfunctionでの複...
-
エクセルのマクロでアクティブ...
-
エクセルのマクロについて教え...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
特定の文字を含むシートだけマ...
-
【ExcelVBA】全シートのセルの...
-
ユーザーフォームに入力したデ...
-
実行時エラー'1004': WorkSheet...
-
XL:BeforeDoubleClickが動かない
-
excelのマクロで該当処理できな...
-
Excelマクロのエラーを解決した...
-
別のシートから値を取得するとき
-
ブック名、シート名を他のモジ...
-
VBA 存在しないシートを選...
-
シートが保護されている状態で...
-
同じ作業を複数のシートに実行...
-
VBAで指定シート以外の選択
-
Excel VBA リンク先をシート...
-
エクセル・マクロ シートの非...
-
実行時エラー1004「Select メソ...
-
ExcelのVBAのマクロで他のシー...
-
【Excel VBA】Worksheets().Act...
-
エクセルVBA Ifでシート名が合...
-
userFormに貼り付けたLabelを変...
おすすめ情報