はじめに
これまでは、Power Apps でコレクションからCSVを作成する方法として、大きく2つあったと思います。
今回は、「新しい関数を使って従来の方法の弱点を克服した」という内容です。
①フローの使用
1つはフローにコレクションを渡す方法です。
こちらは一度JSONへの変換を挟む必要こそありますが、コレクションの中身をあまり意識せずに使用することができるので、使いやすい方法です。
ただし、一度フローを挟む必要があるので、Power Apps だけで完結させたいという場合には使えません。
また、CSVとしての出力形式を指定すること、例えばExcelにそのまま貼り付けられるように、カンマ区切りではなくタブ区切りに変えたいという要望には答えられないという欠点もあります。
②関数の使用
もう1つはPower Apps 内の関数でコレクションの中身を文字列として結合して作成する方法です。
Copy(
With(
{
delimiter: Char(9),
quotechar: """"
},
Concatenate(
quotechar,"ひらがな",quotechar,
delimiter,
quotechar,"アルファベット",quotechar,
delimiter,
quotechar,"数字",quotechar
)&Char(10)&
Concat(
ForAll(
col As X,
Concatenate(
quotechar,X.ひらがな,quotechar,
delimiter,
quotechar,X.アルファベット,quotechar,
delimiter,
quotechar,X.数字,quotechar
)
),
Value,
Char(10)
)
)
)
ただし、この方法はあらかじめ列名がわかっていなければ関数を作成することができないという問題がありました。
また、列が多い場合は1つ1つ列を指定して関数を作るのがとても手間であるという問題もありました。
今回は例として列が3つだけの場合を作成しましたが、列が増えれば増えるほど関数が長くなっていきます。
ColumnNames関数、Column関数
Power Apps に新しい関数として、ColumnNames
関数とColumn
関数が追加されました。
これにより、コレクションの列を動的に取得することができるようになったため、あらかじめ列をすべて指定するという必要がなくなりました!
最終的に出来上がった式
ということで出来上がったのがこちらです。
collection: col
の部分を、CSVに変換したい任意のコレクションに変更することでお使いいただけると思います。
Copy(
With(
{
collection: col, //ここが任意のコレクション
delimiter: Char(9) //区切り文字。Char(9)はタブ文字
},
With(
{names: ColumnNames(ParseJSON(JSON(First(collection))))},
Concat(
names,
Value,
delimiter
) & Char(10) & Concat(
ForAll(
collection As C,
Concat(
ForAll(
names As N,
Column(
ParseJSON(JSON(C)),
N.Value
)
),
Value,
delimiter
)
),
Value,
Char(10)
)
)
)
);
おまけ
値を引用符で囲み、元の値の中に引用符があった場合は、引用符2文字分に変換してエスケープするバージョンです。
Copy(
With(
{
collection: col, //ここが任意のコレクション
delimiter: Char(9), //区切り文字。Char(9)はタブ文字
quotechar: """" //引用符。""""はダブルクォーテーション1文字分
},
With(
{names: ColumnNames(ParseJSON(JSON(First(collection))))},
Concat(
names,
quotechar & Substitute(
Value,
quotechar,
quotechar & quotechar
) & quotechar,
delimiter
) & Char(10) & Concat(
ForAll(
collection As C,
Concat(
ForAll(
names As N,
Column(
ParseJSON(JSON(C)),
N.Value
)
),
quotechar & Substitute(
Value,
quotechar,
quotechar & quotechar
) & quotechar,
delimiter
)
),
Value,
Char(10)
)
)
)
);
申し訳程度の解説
詳細な解説は省略いたしますが、やってることだけサクッと述べておきます。
-
ColumnNames
関数で列名一覧の配列を取得 - 取得した列名一覧を
Concat
関数で区切り文字で挟みながらつなげる - 外側の
ForAll
でコレクションの行ごとにループ - コレクションの各行ごとに内側の
ForAll
で列ごとにループ - 内側のループでは列ごとの値を
Colunm
関数で取り出して区切り文字で結合 - 外側のループでは区切り文字で結合した各行を、改行文字で結合
解説は以上です!