![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?e8efa67)
色々と前の投稿を見ましたが、どうしても答えが分からず質問させてもらいます!!
1から31(1ヶ月)のセルの中で、毎月ランダムにたくさんのアルファベットが入ります。
その中で、「a」というアルファベットのみを別シートに飛ばし、その別シート上では「1」として表記したいです。さらに、その「a」が入った日付も一緒に別シートに飛ばしたいです。
一ヶ月の中で「a」が入るのは2~5回ぐらいなので、別シートには7日分の表を用意するつもりです。
ただ、その1ヶ月の中でどこに「a」が入るかは決まっていません。
日付も全く未定なので、「a」が入ったら別シートに1として、さらに日付が入ったセルの数字も一緒に飛ばす。
マクロは全く分からないので、出来れば関数が良いです!!
A 回答 (5件)
- 最新から表示
- 回答順に表示
No.5
- 回答日時:
こんばんは!
>マクロは全く分からないので、出来れば関数が良いです!!
というコトですので、一例です。
↓の画像のような配置になっているとします。
Sheet2のA2セルに
=IFERROR(INDEX(Sheet1!A$1:A$50,SMALL(IF(Sheet1!B$1:B$50="a",ROW(A$1:A$50)),ROW(A1))),"")
これは配列数式になりますので、Ctrl+Shift+Enterで確定!
この画面からコピー&ペーストする場合は
上記数式をドラッグ&コピー → A2セルを選択 → 数式バー内に貼り付け → そのまま(編集可能なまま)
Ctrl+Shiftキーを押しながらEnterキーで確定!
数式の前後に{ }マークが入り配列数式になります。
B2セル(配列数式ではありません)には
=IF(A2="","",1)
という数式を入れ A2・B2セルを範囲指定 → B2セルのフィルハンドルで下へコピー!
これで画像のような感じになります。
※ お望みの方法でないVBAでもやってみました。
Alt+F11キー → メニュー → 挿入 → 標準モジュール → VBE画面のカーソルが点滅しているところに
↓のコードをコピー&ペースト
Sub Sample1() 'この行から
Dim lastRow1 As Long, lastRow2 As Long, wS As Worksheet
Set wS = Worksheets("Sheet2")
With Worksheets("Sheet1")
lastRow1 = .Cells(Rows.Count, "A").End(xlUp).Row
lastRow2 = wS.Cells(Rows.Count, "A").End(xlUp).Row
Application.ScreenUpdating = False
If lastRow2 > 1 Then
Range(wS.Cells(2, "A"), wS.Cells(lastRow2, "B")).ClearContents
End If
.Range("A1").AutoFilter field:=2, Criteria1:="a"
If Cells(Rows.Count, "A").End(xlUp).Row > 1 Then
Range(.Cells(2, "A"), .Cells(lastRow1, "A")).SpecialCells(xlCellTypeVisible).Copy wS.Range("A2")
lastRow2 = wS.Cells(Rows.Count, "A").End(xlUp).Row
If lastRow2 > 1 Then
Range(wS.Cells(2, "B"), wS.Cells(lastRow2, "B")) = 1
End If
End If
.AutoFilterMode = False
Application.ScreenUpdating = True
End With
End Sub 'この行まで
次に画面左下にある「Sheet1」のSheet見出し上で右クリック → コードの表示 → VBE画面のカーソルが点滅しているところに
↓のコードをコピー&ペースト → Excel画面に戻りSheet1のB列にデータを入力してみてください。
Private Sub Worksheet_Change(ByVal Target As Range) 'この行から
Dim lastRow1 As Long, lastRow2 As Long, wS As Worksheet
Set wS = Worksheets("Sheet2")
If Intersect(Target, Range("B:B")) Is Nothing Then Exit Sub
Call Sample1
End Sub 'この行まで
これでも同じ結果になると思います。
※ VBAの場合はB列の数式が消えてしまいます。m(_ _)m
![「Excelで条件に満たしたセルを飛ばす」の回答画像5](http://oshiete.xgoo.jp/_/bucket/oshietegoo/images/media/8/667667_5497e750a244d/M.jpg)
No.4
- 回答日時:
D4 1
E4 =if(countif(sheet1!B$4:B$34,"a")<d4,"",index(sheet1!a:a,small(index(row(sheet1!B$4:B$34)+999*(sheet1!B$4:B$34<>"a"),),d4)))
F4 =if(e4="","",1)
自動的に転記するためには、上のように、難しい数式が必要です。それよりも、単にオートフィルタで絞り込むだけにとどめるのが通常の手法です。自動にする必要性があまりないケースが多いので。別シートに保存したければ、絞り込んだ状態でコピペしてください。
なおセルに数式をセットするだけではこのように難しいのですが、マクロなら初級レベルでもできる課題です。
![「Excelで条件に満たしたセルを飛ばす」の回答画像4](http://oshiete.xgoo.jp/_/bucket/oshietegoo/images/media/e/1037181_5497e75033c49/M.jpg)
回答ありがとうございます!!
すごい詳しく実際に作ってもらえてありがたいです!
やっぱり数式だとすごい複雑ですね~。
マクロをこれから覚えていこうと思います。
ありがとうございました!
No.3
- 回答日時:
元データのレイアウトがわからないのですが、Sheet1のA2セル以下に日付、B2セル以下に「a」という文字が入力されているなら、別シートのB2セルに以下の式を入力し下方向にオートフィルします。
=IF(COUNTIF(Sheet1!$B$2:$B$32,"a")<ROW(1:1),"",1)
同様にA2セルには以下の式を入力して下方向にオートフィルします。
=IF(B2="","",INDEX(Sheet1!A:A,SMALL(INDEX((Sheet1!$B$2:$B$32<>"a")*100+ROW($2:$32),),ROW(1:1))))
![「Excelで条件に満たしたセルを飛ばす」の回答画像3](http://oshiete.xgoo.jp/_/bucket/oshietegoo/images/media/7/1223543_5497e75006702/M.jpg)
No.2
- 回答日時:
「別シートに飛ばす」ってハヤリなの?
1)オートフィルタ掛けて、「aを含む」を表示させ、
2)セル選択で「可視セル」のみ選択してコピーして、
3)別シートヘペースト
ではダメですか?
No.1
- 回答日時:
>マクロは全く分からないので、出来れば関数が良いです!!
「aを飛ばす」という言葉が、
別シートに”1”を記入して、元のシートから”a”を削除するという意味なら
関数では不可能です。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) EXCEL マクロで 同じフォルダ内の複数ファイルの複数行全体を選択して1つのファイルに集約 4 2022/09/27 18:41
- Excel(エクセル) シート参照を含む数式を連続コピー 3 2022/12/10 11:42
- Excel(エクセル) エクセル関数について 2 2022/04/13 18:25
- Excel(エクセル) 複数セルデータを別シートの単一セルにコピーしたい。(詳細をご参照ください) 1 2022/12/14 15:08
- Excel(エクセル) Excelの複数ファイルの複数行を別ファイル1つのシートにVBA、マクロで集約する方法 5 2022/09/13 06:30
- Excel(エクセル) 条件に合った数値の合計を表示させたい関数と条件指定の方法 3 2023/05/13 16:07
- Excel(エクセル) Excel シート複数 金額日計表と日付 簡単にシートコピーしたら前日の残高と日付を変更させたい 1 2022/07/15 22:10
- Excel(エクセル) エクセルで”入力シート”の文字書式の変更を”出力シート”で同じ文字書式で印刷したいです。VBA希望 4 2023/04/24 11:07
- Excel(エクセル) Excelについて 1 2023/03/06 10:26
- Excel(エクセル) 添付写真上のExcelシートのように時間と曜日ごとに担当者が振り分けられているシートがあります。 例 1 2023/03/08 13:02
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
IFとIFS関数
-
Excelを無料で使うには? パソ...
-
セルの数を求めたい
-
Excelの表示についての質問
-
再質問です。マクロの修正箇所...
-
データチェックを行うエクセル...
-
エクセルで「ページレイアウト...
-
エクセルの数式バーのフォント...
-
エクセルの関数について教えて...
-
エクセルでセルに標準で入力さ...
-
Microsoft1Officeの互換ソフト...
-
シフト表をエクセルで作るとき...
-
ユーザー定義関数をアドイン登...
-
Excel VBAで全ての矢印を赤色に...
-
VBA Private Sub Worksheet_Cha...
-
2列に入っているデータを1列...
-
Excelに詳しい方! B列が「日...
-
excel2013 MonthDays 関数が使...
-
エクセルのクイックアクセスツ...
-
Excelの数式について教えてくだ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
半角カタカナをヘボン式ローマ...
-
(マクロ)vlookupの元データを同...
-
エクセルで上位バイトのセルと...
-
exselの質問です
-
Excel 大小比較演算子による「...
-
Excel VBについての質問です。
-
エクセルの問題です。絶対値の...
-
非表示列の再表示に失敗
-
職場の人から聞かれており、こ...
-
Excel関数-文字列で自動作成さ...
-
Excelデータをコピペして、ペー...
-
ユーザー定義関数をアドイン登...
-
【マクロ】for next構文について
-
エクセルの日付を編集する
-
【マクロ】VLOOKUPにて参照元に...
-
exselで最小数で並び替える関数
-
libre 表計算ソフトの計算がう...
-
エクセルで表
-
エクセルの表で1年間の曜日を...
-
西暦和暦
おすすめ情報