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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

解決済

1回答

1418閲覧

python 3.x value errorで困っています…助けて!

0910pass.py

総合スコア33

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

0グッド

0クリップ

投稿2019/07/21 13:51

編集2019/07/21 14:27

前提・実現したいこと

googleスプレットシートに入力された迷路の表示

使用環境:windows7 PC 使用言語はpython3.7.4です

##質問の内容

1 google drive においてスプレットシートにいくらか複雑な迷路を描き,
against_againstというファイルに保存。

2 against_againstに以下のプログラムを保存。

pro.1ファイル名:maze_show.py

from tkinter import* tile_size=20 def load_map_data(): from maru_data import data return data def draw_map(cv,data): rows=len(data) cols=len(data[0]) for y in range(rows): y1=y* tile_size y2=y1+ tile_size for x in range(cols): x1=x*tile_size x2=x1+tile_size p=data[y][x] if p==0:color="white" if p==1:color="#404040" if p==2:color="red" if p==3:color="blue" cv.create_rectangle( x1,y1,x2,y2, fill=color, outline="black",width=2) def create_window(map_data,events=[]): win=Tk() win.title("迷路") rows=len(map_data) cols=len(map_data[0]) cv=Canvas(win, width=(cols*tile_size), height=(rows*tile_size)) cv.pack() draw_map(cv,map_data) for func in events: func(cv,map_data) win.mainloop() if __name__=="__main__": map_data=load_map_data() create_window(map_data) その後、以下のプログラムの製作。 from tkinter import* from maze_show import create_window def load_map_from_tsv(filename): fp=open(filename,"rt",encoding="utf-8") tsv= fp.read() rows=tsv.split("\n") result=[] for line in rows: cols=line.split("\t") if len (cols)<=1:break cols=list(map(int,cols)) result.append(cols) return result if __name__=="__main__": map_data=load_map_from_tsv("maze2.tsv.tsv") create_window(map_data)

※maze2 とは、googleスプレットシートのagainst_againstへの保存名です※

その後、このプログラムをagainst_againstに保存、名前をmaze_show2.pyとし、実行。

今度こそはうまくいってくれと思っていたら…

エラーメッセージ

Traceback (most recent call last): File "C:\Users\MARUYAMA\Desktop\against_against\maze_show.2.py", line 19, in <module> map_data=load_map_from_tsv("maze2.tsv.tsv") File "C:\Users\MARUYAMA\Desktop\against_against\maze_show.2.py", line 14, in load_map_from_tsv cols=list(map(int,cols)) ValueError: invalid literal for int() with base 10: ''

試したこと

ファイルの誤字・脱字の確認

COLSの直接的な代入

補足情報(FW/ツールのバージョンなど)

出力される筈のGOOGLE スプレットシートの情報

1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 0 0 0 1 0 1 1 0 2 1 1 1 1 1 1 1 1 0 1 1 1 1 0 1 0 1 1 1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0 0 1 1 1 1 0 1 0 1 1 1 0 1 0 1 1 1 0 1 0 1 1 1 1 1 1 1 1 1 1 1 0 1 0 1 1 1 0 0 0 1 1 1 0 1 0 1 1 1 1 1 0 0 0 0 0 1 0 1 0 1 1 1 1 1 0 1 1 0 0 1 0 1 1 1 1 1 0 1 1 1 0 1 0 1 0 1 0 0 0 1 0 1 1 0 1 1 0 0 0 0 1 1 0 1 0 0 0 1 0 1 0 0 0 0 0 1 0 1 1 0 1 1 1 1 1 0 1 1 0 1 1 1 1 1 0 1 0 1 0 0 0 1 0 1 1 0 1 1 1 1 1 0 1 1 0 0 0 0 0 0 0 1 0 1 0 0 0 1 0 1 1 0 0 0 0 0 0 0 1 1 1 1 0 1 1 1 1 1 0 1 0 0 0 1 1 1 1 1 1 1 1 0 1 1 1 1 1 1 0 1 1 0 0 0 0 1 0 0 0 0 0 1 1 0 1 1 1 0 0 0 0 0 0 0 0 1 1 0 1 1 1 1 1 1 1 1 0 1 1 0 1 1 1 1 0 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 1 1 0 0 0 0 0 0 1 0 0 0 1 1 1 1 0 0 0 1 1 1 1 1 1 1 1 1 1 0 1 1 1 1 1 0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 0 1 1 1 1 1 0 1 0 1 1 0 1 1 1 1 0 1 1 1 1 1 0 1 1 1 0 1 1 1 1 1 0 1 0 0 0 0 1 1 0 0 0 1 1 1 1 1 0 1 1 1 0 0 0 0 0 0 0 1 1 1 1 1 1 0 0 1 1 0 0 0 0 0 3 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1

何度も質問申し訳ないです…
どなたかご教授ください~!

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

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

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

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

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

gentaro

2019/07/21 13:57

> File "C:\Users\MARUYAMA\Desktop\against_against\maze_show.2.py", line 19, in <module> map_data=load_map_from_tsv("maze2.tsv.tsv") maze2.tsv.tsvというファイル名は合ってるんすかコレ?
0910pass.py

2019/07/21 14:05 編集

ん?ああ!  そうでした。間違ってますねクォレハ… map_data=load_map_from_tsv("maze2.tsv.tsv")を map_data=load_map_from_tsv("maze2.tsv") 訂正しました。ありがとうございます!
0910pass.py

2019/07/21 14:18

訂正しましたら... Traceback (most recent call last): File "C:\Users\MARUYAMA\Desktop\against_against\maze_show.2.py", line 19, in <module> map_data=load_map_from_tsv("maze2.tsv") File "C:\Users\MARUYAMA\Desktop\against_against\maze_show.2.py", line 6, in load_map_from_tsv fp=open(filename,"rt",encoding="utf-8") FileNotFoundError: [Errno 2] No such file or directory: 'maze2.tsv' とはかれました… maze2 はちゃんとagainst_againstに保存されている筈のなですが… なぜなんでしょう...
hayataka2049

2019/07/21 14:21

コードが読めないので、質問文を編集して<code>ボタンを適切に使ってください。プレブューでちゃんと表示されるようにして
0910pass.py

2019/07/21 14:23

あっ…これは大変申し訳ないことをいたしました… 今訂正します
hayataka2049

2019/07/21 14:33

上のやり取りに関してですが、拡張子を表示しないエクスプローラの設定になってませんか? プログラミングに不向きなので表示させてください。本来のファイル名がmaze2.tsv.tsvになっている可能性もあります。
0910pass.py

2019/07/21 14:45 編集

コメントありがとうございます! 今拡張子を表示するようにしました。 ああっ。確かに、もともとのファイル名はmaze2.tsv.tsvでした…
guest

回答1

0

ベストアンサー

cols=line.split("\t")の中身に改行文字\nとか入ってないですか?このエラーはintに変換できないものが入っていると言っている気がします.

追記
どこでエラーが発生しているか確かめるために、つぎのコードを実行しました。

python

1if __name__ == "__main__": 2 filename = "maze2.tsv" 3 fp=open(filename,"rt",encoding="utf-8") 4 tsv= fp.read() 5 rows=tsv.split("\n") 6 result=[] 7 8 for num, line in enumerate(rows): 9 cols=line.split("\t") 10 if len (cols)<=1:break 11 try: 12 cols=list(map(int,cols)) 13 except: 14 print("Error: ", cols, f"at line {num}") 15 result.append(cols)

その結果がこちらです。

bash

1Error: ['', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '1'] at line 20 2Error: ['', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '1'] at line 21 3Error: ['', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '1'] at line 22 4Error: ['', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '1'] at line 23 5Error: ['', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '1'] at line 24 6Error: ['', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', ''] at line 25 7Error: ['', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', ''] at line 26 8Error: ['', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', ''] at line 27 9Error: ['1', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', ''] at line 28 10Error: ['1', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', ''] at line 29 11Error: ['1', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', ''] at line 30 12

何も入っていない文字(?)が大量に20行目以降に入ってしまっており、これがエラーとなっているようです。

解決方法

何も入っていない文字が量産されていないところは、タブを\tと書くならば

\t\t\t\t\t\t\t\t\t1

のようになっている場所だと思います。なので、タブが複数連続している場所は1つにまとめ、先頭のタブは消すという処理をすれば良いと思います。

python

1import re # 正規表現を使う 2 3filename = "maze2.tsv" 4fp=open(filename,"rt",encoding="utf-8") 5tsv= fp.read() 6rows=tsv.split("\n") 7result=[] 8 9for num, line in enumerate(rows): 10 line = re.sub(r"\t+", "\t", line) # タブが複数あるところは1つに置き換える 11 line = re.sub("^\t", "", line) # 先頭のタブは消す 12 cols=line.split("\t") 13 if len (cols)<=1:break 14 cols=list(map(int,cols)) 15 16 result.append(cols)

これで行けるはず。。。

投稿2019/07/21 14:06

編集2019/07/21 15:20
Yhaya

総合スコア439

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

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

0910pass.py

2019/07/21 14:12

確かに…その可能性もあるかもしれませんね… 今検討してみます。ありがとうございます!
0910pass.py

2019/07/21 14:19

今確認しました。今のところ入っていないように思われます…。
Yhaya

2019/07/21 14:25

こっちでも適当なtsvを作って試してみているのですが、エラーが出ないですね、、、。 差し支えなければ、maze.tsv.tsvを一部テキスト形式で見せてもらうことは出来ますか(特に最初と最後)?
0910pass.py

2019/07/21 14:29

もちろんです。 ありがとうございます!
0910pass.py

2019/07/21 14:39

https://docs.google.com/spreadsheets/u/2/d/16ANhtflMJ3Uk8dTSxYMe8n3SwhSbhfNTrJDzHOaWSGM/export?format=tsv&id=16ANhtflMJ3Uk8dTSxYMe8n3SwhSbhfNTrJDzHOaWSGM&gid=0 こちらがダウンロード用urlで テキスト形式のものはこちらになります 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 0 0 0 1 0 1 1 0 2 1 1 1 1 1 1 1 1 0 1 1 1 1 0 1 0 1 1 1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0 0 1 1 1 1 0 1 0 1 1 1 0 1 0 1 1 1 0 1 0 1 1 1 1 1 1 1 1 1 1 1 0 1 0 1 1 1 0 0 0 1 1 1 0 1 0 1 1 1 1 1 0 0 0 0 0 1 0 1 0 1 1 1 1 1 0 1 1 0 0 1 0 1 1 1 1 1 0 1 1 1 0 1 0 1 0 1 0 0 0 1 0 1 1 0 1 1 0 0 0 0 1 1 0 1 0 0 0 1 0 1 0 0 0 0 0 1 0 1 1 0 1 1 1 1 1 0 1 1 0 1 1 1 1 1 0 1 0 1 0 0 0 1 0 1 1 0 1 1 1 1 1 0 1 1 0 0 0 0 0 0 0 1 0 1 0 0 0 1 0 1 1 0 0 0 0 0 0 0 1 1 1 1 0 1 1 1 1 1 0 1 0 0 0 1 1 1 1 1 1 1 1 0 1 1 1 1 1 1 0 1 1 0 0 0 0 1 0 0 0 0 0 1 1 0 1 1 1 0 0 0 0 0 0 0 0 1 1 0 1 1 1 1 1 1 1 1 0 1 1 0 1 1 1 1 0 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 1 1 0 0 0 0 0 0 1 0 0 0 1 1 1 1 0 0 0 1 1 1 1 1 1 1 1 1 1 0 1 1 1 1 1 0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 0 1 1 1 1 1 0 1 0 1 1 0 1 1 1 1 0 1 1 1 1 1 0 1 1 1 0 1 1 1 1 1 0 1 0 0 0 0 1 1 0 0 0 1 1 1 1 1 0 1 1 1 0 0 0 0 0 0 0 1 1 1 1 1 1 0 0 1 1 0 0 0 0 0 3 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
0910pass.py

2019/07/21 14:52

申しわけありません! 今しがた共有を可能にしました…
Yhaya

2019/07/21 14:57

ありがとうございます!
0910pass.py

2019/07/21 15:16

ではどうやってエラーを回避すればよいのでしょうか? 教えていただけますか…? 長時間にわたるご協力、筆舌つくせぬ程感謝します。
Yhaya

2019/07/21 15:19

今追加しました!
0910pass.py

2019/07/21 15:23

おおおおおおおおおおおおおおおおおおおおおおおおおおおおおおおおおお! エラー確認されませんでした!!
0910pass.py

2019/07/21 15:46 編集

このプログラミングを活用して創ってみます!ありがとうございます!
Yhaya

2019/07/21 15:25

おめでとうございます!!!
0910pass.py

2019/07/21 15:43

今しがたプログラム完成しました… これでどうでしょう...。 ''' from tkinter import* from maze_show import create_window def load_map_from_tsv(filename): fp=open(filename,"rt",encoding="utf-8") tsv= fp.read() rows=tsv.split("\n") result=[] for num, line in enumerate(rows): line = re.sub(r"\t+", "\t", line) line = re.sub("^\t", "", line) cols=line.split("\t") if len (cols)<=1:break cols=list(map(int,cols)) result.append(cols) return result if __name__=="__main__": map_data=load_map_from_tsv("maze2.tsv.tsv") create_window(map_data) '''
0910pass.py

2019/07/21 15:47

```ここに言語を入力 from tkinter import* from maze_show import create_window def load_map_from_tsv(filename): fp=open(filename,"rt",encoding="utf-8") tsv= fp.read() rows=tsv.split("\n") result=[] for num, line in enumerate(rows): line = re.sub(r"\t+", "\t", line) line = re.sub("^\t", "", line) cols=line.split("\t") if len (cols)<=1:break cols=list(map(int,cols)) result.append(cols) return result if __name__=="__main__": map_data=load_map_from_tsv("maze2.tsv.tsv") create_window(map_data) ```
0910pass.py

2019/07/21 15:49

問題解決しました!ほんとうにありがとう!
Yhaya

2019/07/22 00:34

返信遅れて申し訳ないです。問題解決したようで何よりです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問