FileMaker 同一フィールドに同じ値が連続している個数をかえすスクリプト
当方はFileMaker Pro 5.5を使用しています。初心者です。
----------------
甲乙
A3
A3
A3
B2
B2
C4
C4
C4
C4
D1
A2
A2
C1
----------------
フィールド甲を参照し、同じ値が連続している個数をフィールド乙に返すスク
リプトを組みたいと考えています。
たとえば、一番上のレコードから「A」が3回続いているため、フィールド乙には
3をかえします。同様に全レコード繰り返します。
フィールド甲の値は一度連続が途切れたあとも、後のレコードで再度でてくることも
あります。
よいスクリプトはありますでしょうか。
No.1ベストアンサー
- 回答日時:
FM5.5では変数が使えないので、グローバルフィールドを使います。
まず前のフィールドと比較するために、フィールドタイプをグローバル(テキスト)にして、新規フィールドを作って下さい。
そして演算結果を入れるためのフィールドを同様にフィールドタイプをグローバル(テキスト)にして、新規フィールドを作ります。
ここではそれぞれ、「前のフィールド値」、「チェック結果」とします。
後は以下のようにループさせればいいだけです。
ーーーーーーーーーーーーーーーーーー
レコード/検索条件/ページへ移動[最初の]
フィールド設定[前のフィールド値],[甲]
Loop
フィールド設定[チェック結果],[if(甲=前のフィールド値,前のフィールド値+1,0)]
フィールド設定[乙],[if(甲=前のフィールド値,"",チェック結果)]
フィールド設定[前のフィールド値],[甲]
レコード/検索条件/ページへ移動[次の][最後まで来たら終了]
End Loop
ーーーーーーーーーーーーーーーーーー
直このやり方だと、連続する最後のフィールドのみ値を入れるようにしています。
連続するフィールドすべてに入れるには、リレーション用のフィールドを新規に作って同じ値が続く間は同じ数値を入れるようにして下さい。
その後、そのフィールドでリレーションを組んであげて、
計算式にしたフィールドに[甲]の値を入れてあげればOKです。
回答ありがとうございました。
また、回答への返礼遅れ失礼しました。
連続する最後のフィールドのみ値を入れるようになるところまで、おかげさまでできました。
そのあとですが、リレーションを組んでというところが、自分のスキルがそこまで達していなくてうまくできませんでした。
自己流ですが、回答を参考にしながら、フィールド3つ(うちグローバルフィールド1つ)をさらに追加しまして、同じくLoopを用い方法で何とかできました。
No.2
- 回答日時:
フィールド甲をキーとして自己リレーションさせ、
計算式(Count関数)でフィールド内容の全置換
変更をリアルタイムで反映させたいならフィールド乙は計算式にしたほうが良いかも。
FileMakerPro5.5でも確か出来たと思います。
No.3
- 回答日時:
No2さんの方法だと、無理では?
質問者は「一致するフィールド数」ではなく、「連続するフィールド数」を知りたがってます。
しかも、例を見るとAという値が何度も繰り返し出ることがあるようです。
手間ですがLoopで回すしかないと思います。
No.4
- 回答日時:
間違えてしまいましたすみません。
正しくは、
新しいフィールドを3つ作ります
ID1:フィールドタイプ数字
ID2:フィールドタイプ計算 ID1+1
ID3:フィールドタイプ数字
ID1=ID2で自己リレーション "ファイルB"
ID3=ID3で自己リレーション "ファイルC"
スクリプト
ID1フィールド フィールドの内容の全置換 シリアル番号 増分1
ID3フィールド フィールドの内容の全置換
If ( ファイルA::甲 = ファイルB::甲 ; ファイルB::ID3 ; ファイルA::ID1 )
乙フィールド フィールドの内容の全置換 Count ( ファイルC::ID )
回答ありがとうございました。
また、回答への返礼遅れ失礼しました。
当方FM初心者です。回答いただいた内容についてネットも見ながら試行錯誤しました。残念ながら、自分のスキルが、回答内容を活用するところまでの水準まで達しておらずうまくいきませんでしたので、今後勉強していきたいと思います。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Access(アクセス) アクセスの更新クエリでカレントレコードのみ更新したい 1 2022/06/02 23:32
- その他(データベース) 更新クエリをリンクデータベーステーブルに実行し実行時エラー3362固有インデックスに重複する値が含ま 1 2022/09/21 11:44
- Access(アクセス) Accessのクエリの結果を、既存のエクセルに追加したい 2 2022/07/31 22:44
- SQL Server ACCESSで表が作りたく、そのためのSQL文や設定方法を教えてください。 1 2022/08/15 12:28
- その他(データベース) IT用語について質問です。 以前ITパスポートの試験を受けた際にデータベースが何の集まりかについての 2 2022/12/10 12:29
- その他(データベース) Accessのクエリで1フィールドの抽出条件設定をNullでなく全角半角含む空白のみの文字列でない文 1 2023/04/24 15:20
- PHP クエリObjectをforeachで回す時に、次のレコードへ移動せずに次のレコードを取得したい 2 2022/07/28 15:29
- Access(アクセス) Accessテーブルの結合で別々のテーブルのフィールドを組み合わせて値を出す方法について 2 2022/07/20 19:43
- Access(アクセス) Accessフォーム 一部のレコードだけを抽出する方法について 1 2022/06/28 18:45
- Access(アクセス) Accessテキストボックス内に2つのフィールドの値を比較して大きい方の値を表示させる方法 1 2022/09/09 10:50
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「#エラー」の回避
-
ExcelからAccessデータを検索す...
-
アクセスで入力したデータの順...
-
WORDのIFにEqフィールドは使えない
-
WORD差し込み印刷:日付の処理 ...
-
accessのフィールドに10桁の数...
-
ファイルメーカー8で、納品書...
-
ACCESSでデータ変更箇所が分か...
-
ファイルメーカーでフォルダパ...
-
Accessクエリ 複数のIF関数の...
-
MS-WORDで、あるフィールドに入...
-
MS-ACCESSで中央値(ME...
-
ファイルメーカーの集計方法を...
-
Access フィールド内の値で、...
-
Accessでボタンを押すと今日の...
-
差し込み文書のルールで if the...
-
Accessで、他の二つのフィール...
-
ファイルメーカーで時間と金額...
-
ファイルメーカーのMax関数につ...
-
FileMakerで読み込んだファイル...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
アクセスで入力したデータの順...
-
「#エラー」の回避
-
差し込み文書のルールで if the...
-
accessのフィールドに10桁の数...
-
ExcelからAccessデータを検索す...
-
Accessで値がnullの場合は計算...
-
Accessでボタンを押すと今日の...
-
FileMakerで画像をまとめて書き...
-
WORD差し込み印刷:日付の処理 ...
-
ACCESSでデータ変更箇所が分か...
-
Access フィールド内の値で、...
-
MS-WORDで、あるフィールドに入...
-
FileMakerで、フィールドの値が...
-
access フィールドのサイズ(文...
-
Wordでページ番号を計算式で入...
-
フィールドの中のテキストを分...
-
FileMakerで外部保存PDFを開く方法
-
ファイルメーカーの集計方法を...
-
ワードでプルダウン項目を作りたい
-
Access フィールドに入力した...
おすすめ情報