はじめに
こんにちは、G-Blossomエンジニアのぴーよです!
今回はUEでのCSVの取り扱い方について実践しつつご説明しようと思います。
UEでCSVを取り扱う手法は大きく2種類あります。
1. DataTableを作ってインポート
- 良い点
- 非常に強力な機能でワークフローが充実している
- 様々な型を利用できる
- 注意点
- 複数行のヘッダーを使えない
- キーバリュー型での取り扱いになるので、条件づけて絞り込みは工夫が必要
- トランザクション的な運用はできない。あくまでマスタ
2. CSVをテキストで読み込んでパースする
- 良い点
- 複数行のヘッダーも読み込める
- 特定の座標でデータを拾えるのでマッピングの自由度が高い
- ファイルへの書き出しも可能なのでトランザクションにすることも可能(推奨するかは別)
- 注意点
- パーサーを自前で用意しないといけない
- 基本的にStringで取得する
今回は2の発展形で、パーサーのプラグインを使用します
Blueprint CSV Parsing
https://www.fab.com/ja/listings/1f5fc0dd-6b38-475b-8e5d-4dddae0d5852
今回の目標
CSVオブジェクトを作成して任意の値を取れるようになろう!
手順
1. Blueprint CSV Parsingをエンジンにインストール
前述のBlueprint CSV Parsingをご利用のUEのバージョンに対応するものをFabからダウンロードしてインストールします。
https://www.fab.com/ja/listings/1f5fc0dd-6b38-475b-8e5d-4dddae0d5852
2. プラグインの有効化
プロジェクトのプラグイン設定からBlueprintCSVParsingのチェックボックスをtrueにして有効化します。
3. CSVの格納場所の作成
今回はプロジェクト直下にInputData/CSV
のフォルダを作成します。
今回はテストデータとしてこちらを使います。右クリックで保存し、配置してください。
test.csv
内容
,test1,test2,test3
a,1,11,111
b,2,22,222
c,3,33,333
4. 関数の作成
任意のBlueprintにCSV Load関数を作成します。インプットアウトプットは画像参照
5. ファイルの読み込み部の作成
CSV Load関数を開き、Text File Load to String
ノードへ接続します。
Filenameはフルパス付きのファイル名の必要があるので、Get Project Directory
でプロジェクトのディレクトリを取得して、InputData/CSV
内を指定しています。
引数のCSVFileNameに直接ファイル名を指定すれば良い形です。
6. CSVオブジェクトの成型
5.の続きにBranch
ノードを繋ぎ、True
にParse CSV Rows
ノードをつなぎます。CSVStringに先ほどのText File Load to String
で取得したFileData
をつなぎ、ReturnValue
をReturnNode
のCSVObject
に繋ぎ、Successにチェックを入れます。
False側には直接ReturnNode
をつなぎ、チェックが入っていないことを確認して完成。
7. 関数の呼び出し
イベントグラフのBeginPlayでテストしてみましょう。
BeginPlayから引っ張ってCSVLoadを呼ぶと、CSVFileNameに入力できるようになっています。
ここにCSVファイル名を入力するとCSVObjectが取れるようになりました。
実際に値を見てみましょう。
CSVObjectから引っ張って適当な変数を作り、ブレークポイントを設定して実行すると画像の様になります。
行と列情報が取れていることがわかりますね。
8. 任意の座標の取得
ここまでくれば色々な方法で値を取得できます。
CSVObjから引っ張ってgetで検索してみましょう。
CSVグループの中に色々ありますね、実際に置いてあげるとこんな感じ。
どの取得方法もインデックスでも名前でも取れるようになっていますね。
個人的には良くGet Row by Keyを多用しています。条件付けする際にも何かと使えるのでオススメです
最後に
ゲームバランス等を考える際にパラメータ調整をプロジェクトから切り離したいケースなどでは気楽に扱えます。
めざせ爆速テスト環境!
参考資料
パッケージ化の際に役立つかも
【UE4】外部ファイルを含んだprojectをpackagingするときの注意点
https://tyojugiga.hatenablog.com/entry/2019/10/25/113457