質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Unity

Unityは、Unity Technologiesが開発・販売している、IDEを内蔵するゲームエンジンです。主にC#を用いたプログラミングでコンテンツの開発が可能です。

Q&A

解決済

2回答

1618閲覧

Unity CSVファイルを読み込むコードを作ったが、そのCSVをエクセルで編集、保存するとエラーが出る。

Sashimi_ShowYu

総合スコア61

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Unity

Unityは、Unity Technologiesが開発・販売している、IDEを内蔵するゲームエンジンです。主にC#を用いたプログラミングでコンテンツの開発が可能です。

0グッド

0クリップ

投稿2019/05/13 10:22

CSVファイルを読み込んで変数に代入するコードを書いています。今は解説サイトを作ってくれてる人のコードをそのまま使って実験的にやっており、CSVの読み込み自体は成功しています。
ですが、少し問題があります。これについての相談です。

問題点
CSVファイルをExcelで編集して保存してから、Unityに戻ってくると、何も押さなくても、以下の2つのエラーが出ます。

①Cancelling DisplayDialog because it was run from a thread that is not the main thread: Opening file failed Opening file H://Resources/testCSV.csv: プロセスはファイルにアクセスできません。別のプロセスが使用中です。
②File couldn't be read

ここから、さらにプログラムを実行すると、以下のようにヌルエラーが出て正常に動作しません。
NullReferenceException: Object reference not set to an instance of an object
CSVReader.Start () (at Assets/CSVReader.cs:14)

そして、たちが悪いのは、一度そうやってエラーが出ると、その後Excelを終了させても、もう直りません。もはや何をしようがエラーになります。

ちなみに、上記のExcelで編集保存というのは、CSVファイルをwindowsのエクスプローラー上からExcelで開いて編集し、Excel上で保存、という流れです。
でも、以下だと問題なく動きます。
同様にエクスプローラー上でExcelで編集、保存→そのExcelを終了させる→Unityに画面切り替え→プログラム実行
つまり、編集後Excelさえ終了させてれば問題ないです。エラーの「別のプロセスが使用中です。」とはそういうことなのでしょう。

じゃあ、そうやって毎回Excelを終了させればいいじゃないか、という話もあると思いますが、ゲームの敵キャラのデータをCSVで入力しようとしていて、で、CSVをいじるたびにExcel終了していては、ゲームの調整があまりに面倒なのです。それだったらCSVでやらなくていいや、というレベルになってしまいます。

解決方法を教えていただければ助かります。

Excel読み込みのコードも書いておきます。(出典:若狹健太さま)

using System.Collections.Generic; using UnityEngine; using System.IO; public class CSVReader : MonoBehaviour { TextAsset csvFile; // CSVファイル public int height; // CSVの行数 List<string[]> csvDatas = new List<string[]>(); // CSVの中身を入れるリスト; void Start() { csvFile = Resources.Load("testCSV") as TextAsset; // Resouces下のCSV読み込み StringReader reader = new StringReader(csvFile.text); // , で分割しつつ一行ずつ読み込み // リストに追加していく while (reader.Peek() > -1) // reader.Peaekが0になるまで繰り返す { string line = reader.ReadLine(); // 一行ずつ読み込み csvDatas.Add(line.Split(',')); // , 区切りでリストに追加 height++; // 行数加算 } // csvDatas[行][列]を指定して値を自由に取り出せる Debug.Log(csvDatas[0][1]); }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

既に回答が付いている通りです。

Excelで開くという事は、Excelが該当のファイルをオープンします。この時、Excelは、そのファイルを排他ロックするので、他のアプリ(Unityもそう)で開くとエラーとなります。回避するには、当然ながら、Excelをクローズする。または、ぺ別名でファイルの保存を行う、、となります。

... LibroOfficeで開いたら、Readでは開けました。使い勝手はともかく、使えるでしょうか?

参考までに。

投稿2019/05/13 12:21

pepperleaf

総合スコア6383

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Sashimi_ShowYu

2019/05/13 15:36

排他ロックというのがあるのですね。 ありがとうございます。 >LibroOfficeで開いたら、Readでは開けました。 Readで開くというのは、読み込みのみということですよね。 編集して保存をしたいのです。 それとも、それも可能ということでしょうか?
pepperleaf

2019/05/14 11:25

LibroOfficeでの編集/保存は可能。 ただし、同時に 他のアプリ(Unity?) での書込みは不可。読込みのみです。
Sashimi_ShowYu

2019/05/14 11:30

なんと、編集保存できるのですね。readというのを理解してなかったです。 そのアプリも試してみます。 何かと色々追加情報ありがとうございます。
guest

0

ベストアンサー

エクセルで編集するとファイル摑まれる問題はUnity側ではどうしようもないので、エディタ(VSCode)で編集するのではだめですかね?

投稿2019/05/13 10:39

papinianus

総合スコア12705

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Sashimi_ShowYu

2019/05/13 15:33

ありがとうございます。 VSCodeというのがあるのですね。 こちらだと、編集画面を起動したまま、Unityを動かしても一切問題なかったです。 ただ、VSCode上だとCSVファイルがマス目状(Excelみたいな感じ)で値が表示されないので、見にくいです。 なので拡張機能を入れてみました。しかし、どれも駄目でした。 Rainbow CSV →マス目状に表示する機能はあるものの、その状態で編集は不可 Excel Viewer →そもそも編集自体不可 どうにか、マス目状で編集して、かつファイルを掴まないエディタはないでしょうか?
Sashimi_ShowYu

2019/05/14 03:05

ありがとうございます。 そのアプリでばっちりいけました。 ロックしないで、マス目編集ができるアプリ・・という誰も知らなさそうなものを、しかも10年以上前のもので出てくるとは・・・。知識量に驚きです。 本当に感謝です。 ありがとうございました<(_ _)>
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問