質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

Q&A

解決済

2回答

1470閲覧

複数条件の中で最大となる値の行を取り出す

woria

総合スコア36

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

0グッド

0クリップ

投稿2020/06/08 03:59

編集2020/06/08 03:59

前提・実現したいこと

ExcelでLogTableを入力すると、1か月ごとの算定開始日付より古いデータの中で最も新しい距離・備考データをViewテーブルに数式で入力したいです。

LogTable
|入力日|コード|距離|備考|
|:--:|:--:|:--:|
|2000/1/1|a111|10|初期値|
|2000/1/1|b222|20|初期値|
|2000/1/1|c333|30|初期値|
|2020/4/1|a111|5|住所変更|
|2020/4/20|b222|15|住所変更|
|2000/5/1|a111|25|出向|

View(コードと算定開始日付を入力すると、距離と備考が数式で求まる)
[距離]=(View[@コード]=LogTable[コード]) AND View[@算定開始日付]>LogTable[入力日] の中で最も新しい日付(MAX) の距離
[備考]=(View[@コード]=LogTable[コード]) AND View[@算定開始日付]>LogTable[入力日] の中で最も新しい日付(MAX) の備考

コード(=入力)算定開始日付(=入力)距離(=数式)備考(=数式)
a1112020/3/1610初期値
a1112020/4/165住所変更
a1112020/5/1625出向
b2222020/3/1620初期値
b2222020/4/1620初期値
b2222020/5/1615住所変更
c3332020/3/1630初期値
c3332020/4/1630初期値
c3332020/5/1630初期値

試したこと

INDEX + SUMPRODUCT関数等いろいろ試しましたが、

  • あいまいな複数条件の中で
  • 指定フィールドが最大の行から
  • 指定フィールドを出力する

数式を見つけることができませんでした。

補足情報(FW/ツールのバージョンなど)

Office 365
Excel 2016

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

Viewテーブルのサンプル間違ってませんか? 算定開始日 2020/3/16 なら 距離は 25では?

それは置いといて、回答がつかないようなので久しぶりにExcel関数を触ってみました。

算定開始日付(=入力) と 距離(=数式) の間に 1行作業用の列を追加して、
MAXIFSで 条件に合致する 該当入力日 を出力してから INDEX + SUMPRODUCT の複数条件抽出。
これでいけると思います。
(まとめて記述もできそうですが、分けた方がわかりやすいと思います)

INDEX + SUMPRODUCTの参考
http://office-qa.com/Excel/ex352.htm

投稿2020/06/10 10:23

sawa

総合スコア3002

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

Viewテーブル
「算定開始日付」と「距離」の間に「入力日」を挿入し、下記数式を入力
※項目名の(=入力)などの文言は消しています。
入力日

Excel

1=MAXIFS(LogTable[[#すべて],[入力日]],LogTable[[#すべて],[コード]],[@コード],LogTable[[#すべて],[入力日]],"<"&[@算定開始日付])

距離

Excel

1=INDEX(LogTable[[#すべて],[距離]],SUMPRODUCT((LogTable[[#すべて],[コード]]=[@コード])*(LogTable[[#すべて],[入力日]]=[@入力日]),ROW(LogTable[[#すべて],[距離]])))

備考

Excel

1=INDEX(LogTable[[#すべて],[備考]],SUMPRODUCT((LogTable[[#すべて],[コード]]=[@コード])*(LogTable[[#すべて],[入力日]]=[@入力日]),ROW(LogTable[[#すべて],[備考]])))

投稿2020/06/22 20:01

radames1000

総合スコア1925

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

woria

2020/06/22 23:44

数式を実際に打ち込んで、正常に入力できていることを確認しました。ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問