実現したいこと
PowerBIのクエリで複数要素が該当するかどうかを実現したい。
1つのExcelファイルの特定の列に関して該当する要素があるかどうかの判定方法は以前教えて頂きましたが、今回は
C:\Users\0000910170\OneDrive - XXX\SmartAccessMecha\Smart_Access_Data\アクセスデータ"
というフォルダの下に複数のフォルダがあり、そのフォルダの中に複数のcsvファイルがあります。
これらのcsvファイルをPowerBIで取り込み、JSONの処理をして必要な列のあるテーブルを作成し、式は以下のようになっています。
ーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーー
let
ソース = Folder.Files("C:\Users\XXXX\OneDrive\SmartAccessMecha\Smart_Access_Data\アクセスデータ"),
#"フィルター選択された非表示の File1" = Table.SelectRows(ソース, each [Attributes]?[Hidden]? <> true),
カスタム関数の呼び出し1 = Table.AddColumn(#"フィルター選択された非表示の File1", "ファイルの変換", each ファイルの変換([Content])),
#"名前が変更された列 1" = Table.RenameColumns(カスタム関数の呼び出し1, {"Name", "Source.Name"}),
削除された他の列1 = Table.SelectColumns(#"名前が変更された列 1", {"Source.Name", "ファイルの変換"}),
展開されたテーブル列1 = Table.ExpandTableColumn(削除された他の列1, "ファイルの変換", Table.ColumnNames(ファイルの変換(#"サンプル ファイル"))),
変更された型 = Table.TransformColumnTypes(展開されたテーブル列1,{{"Source.Name", type text}, {"RecordId", type text}, {"CreationDate", type datetime}, {"RecordType", Int64.Type}, {"Operation", type text}, {"UserId", type text}, {"AuditData", type text}, {"AssociatedAdminUnits", type text}}),
フィルターされた行 = Table.SelectRows(変更された型, each ([RecordId] <> "]""")),
#"解析された JSON" = Table.TransformColumns(フィルターされた行,{{"AuditData", Json.Document}}),
#"展開された AuditData" = Table.ExpandRecordColumn(#"解析された JSON", "AuditData", {"ObjectId", "SourceFileExtension", "SourceFileName"}, {"AuditData.ObjectId", "AuditData.SourceFileExtension", "AuditData.SourceFileName"}),
フィルターされた行1 = Table.SelectRows(#"展開された AuditData", each true)
in
フィルターされた行1
ーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーー
<実現したいこと>
"AuditData.ObjectId"の行ににある要素に関して除外ワードリストというテーブルにある除外ワードの列の要素を含むか含まないかを判定する列を作りたいと考えています。
前提
前回教えてもらった1つのExcelファイルの特定の列に関して該当する要素があるかどうかの判定方法は以下のようになっています。
前回の場合は"AuditData.ObjectId"ではなく、"コンテンツの場所"で判定しています。
ーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーー
let
//除外ワードを含むか否かを判定する関数を作る
IsExcluded = (Expression as text) =>
let
//テーブル[除外ワードリスト]の[除外ワード]列に、引数 Expression に渡されたテキストと部分一致する要素が存在する場合は true を、存在しない場合は false を返す
Judgement = List.MatchesAny(除外ワードリスト[除外ワード], each Text.Contains(Expression,_))
in
Judgement,
//ワークブックの参照
ソース = Excel.Workbook(File.Contents("C:\Users\XXXX\OneDrive\My_Data\アクセス履歴\Test\新しいフォルダー\全ユーザー結果_01.xlsm"), null, true),
//ワークシートの参照
データ_Sheet = ソース{[Item="データ",Kind="Sheet"]}[Data],
//1行目をヘッダー行として使用
昇格されたヘッダー数 = Table.PromoteHeaders(データ_Sheet, [PromoteAllScalars=true]),
//各列のデータ型を変換
変更された型 = Table.TransformColumnTypes(昇格されたヘッダー数,{{"アクセス日時", type datetime}, {"ユーザー", type text}, {"コンテンツの場所", type text}}),
//それぞれのレコードの[コンテンツの場所]の値を上記の IsExcluded 関数によって評価した結果を新たなカスタム列として追加する
追加されたカスタム = Table.AddColumn(変更された型, "いずれかの除外ワードを含んでいる", each IsExcluded([コンテンツの場所]))
in
追加されたカスタム
ーーーーーーーーーーーーーーーーーーーーーーーーーーーーー
元のデータが単独のExcelか複数のcsvファイルの違いによりソースの定義が異なること、教えてもらった式をcsvファイルのデータを読み込んでJSON処理したテーブルの式に単純に追加できないことが分かり困っています。
解決する式を教えて頂けると幸いです。よろしくお願いいたします。
0 コメント