さて、今回はスクリプト引数についてです。
FileMaker バージョン15まではスクリプト引数のやり方としては、改行コードや固有の記号で区切ったりしていましたが、バージョン16からJSON,cURLが実装されたことから、JSON形式でスクリプト引数を実装できるようになりました。
(正確には、「やろうと思えばやれる」?)
JSONの基本的な使い方は、過去の記事にも書いていますが、今回はJSON形式でスクリプト引数を実装するときのTipsについて書きます。
FileMakerは得意だけれど、JSONは尻込みしてしまう方もいらっしゃるのではないでしょうか?
世の中の主流に一歩近づくためにも、JSON、慣れていきましょうね。
JSON形式をスクリプト引数に実装するってどういうこと?
JSON形式では、
keyとvalueをワンセット
にして保持できます。
フィールド名を指定したら、そのフィールドに入っているデータを取得できるのと同じように、keyを指定したらそこに保存されているvalueが取得できます。
これをスクリプト引数に応用する形です。
例えば、
・id
・name
・cnt
というフィールドのデータをスクリプトの引数にしたい場合、
"id"をkeyに、idの値をvalueにして(以下同様)スクリプトに渡し、「idくれ」と言うと「idはこのデータ」と渡してくれる、と言う感じでしょうか。
メリットは?
メリットは、
・引数の順番に左右されない
ことです。
FileMakerのスクリプト引数は、複数の引数を使う場合、その順番に気をつけなければなりません。
JSONでは、先に述べたようにkeyとvalueで実装できるので、順番を気にする必要はありません。
デメリットは?
デメリットは、
・JSONの書き方を覚える
・データの型を気にする
というところです。
JSONの書き方は、通常の関数と同様に提供されているので、覚えるしかありません。
しかし、データの型を気にするのは他の高水準言語ではよくありますが、今までのFileMakerの引数では考えなかったことではないでしょうか?
JSON形式は、値のタイプとして
・JSONString
・JSONNumber
・JSONObject
・JSONArray
・JSONBoolean
・JSONNull
・JSONRaw
の種類があります。
これらを意識してセットすることになるので、テーブル定義で設定したデータの型を確認しなくてはなりません。
JSON形式でセットするときのTips
値のタイプを実は数字で指定できる
値のタイプを文字列でセットするのは、覚えるのが大変、、、と思いますが、実は数字でも指定できます。
詳しくはヘルプをご覧ください。
ここでは、値のタイプについて文字列と数字を表にします。
|文字列|数字|
|------+----|
|JSONString|1|
|JSONNumber|2|
|JSONObject|3|
|JSONArray|4|
|JSONBoolean|5|
|JSONNull|6|
|JSONRaw|0|
わかりやすいのは文字列ですが、綴りを間違えたくないという場合は、数字での実装が簡単かもしれません。
スクリプトを実行するボタンをクリックすると、JSON引数で指定したデータをそれぞれ取得して「スクリプト実行結果」に表示する、という単純なサンプルです。
JSONNullを活用しよう
今までの引数の指定方法で、複数引数があるときに値が存在しない、もしくは指定しない場合、
「""」
を指定していた方もいらっしゃるのではないでしょうか?
もともとFileMakerではデータベースの概念として「空白」は「""」として表現していて、他言語でもよくあります。
また、「空白・空白でない」をチェックする"IsEmpty"関数が使われてきました。
空白を指定するときは「""」という文字列を指定するときのダブルクォーテーションですが、技術者間の連携不足で何かしらの修正などで文字列に変わることもあります。(経験者)
JSON形式では、「空白」として明示的にNULLが使用できますので、JSONNullを使って、明示的に「そのキーには値が存在しない」とできます。
本当に余談ですが、他言語経験が長い私は、「空白とNULLは違う」世界(""はデータのアドレスが確定するが、NULLはアドレスが確定しないなどなど)でしたので、文字列にNULLを突っ込む場面は「 NullPointerException ...」と若干焦ります。( 空文字 の扱いは、言語によって色々あります)
実際のvalueに当たる部分にも、JSONNullを指定できます。
※この場合、JSONNullを指定したというのは、「指定する値がない」ということなので、指定したフィールドの値が空白かどうか、ということではありません。
引数のタイプは、もちろんJSONNullです。
実行すると、JSONFormatElementsで取り出してみるとJSON型のスクリプト変数値のnameにnullが設定されていること、そしてローカル変数に取り出して表示すると何も表示されない("")ことがわかります。
JSONBooleanを活用しよう
TRUE/FALSEを指定するときや、ON/OFFを指定するとき、1と""などローカルに決めていませんでしたか?
なんのための1なのか、なんのための""なのか、可読性が低くなりがちです。
TRUE
JSONBooleanなら、TRUE/FALSEをそのまま使えます。
スクリプトのIF文では、booleanなのでそのまま今まで通りtrue/falseができます。
JSONの中ではtrue、変数に保存すると、trueは「1」で保存されます。
FALSE
falseはどうでしょう。
これもそのまま"false"と指定して、タイプをJSONBooleanにするだけです。
falseは、JSONでは"false"、変数では「0」なので、true同様スクリプト内でもそのまま活用ができます。
スクリプト名にkey名をつける
key名はスクリプトを開かないとわからないのは、通常のスクリプト引数と一緒です。
これだとJSONを使っているありがたさが半分しかないです。
他の方もやられているかと思いますが、スクリプト名にkey名をつけて実装するのがおすすめです。
こうしておくと、スクリプトの引数を指定するときにわかりやすいです。
まとめ
JSONをスクリプト引数で使うときの便利なところ、ぜひ実感してください。
JSONSetElement,JSONGetElementの2つをセットで覚えてしまえば、スクリプト引数でkey-value方式の確かなデータの受け渡しができますので、活用してみてくださいね。