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

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

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

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

Tkinter

Tkinterは、GUIツールキットである“Tk”をPythonから利用できるようにした標準ライブラリである。

Q&A

解決済

1回答

4329閲覧

'int' object has no attribute 'csv'エラーが出る

退会済みユーザー

退会済みユーザー

総合スコア0

Python 3.x

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

Tkinter

Tkinterは、GUIツールキットである“Tk”をPythonから利用できるようにした標準ライブラリである。

0グッド

0クリップ

投稿2019/06/06 04:15

編集2019/06/06 04:40

前提・実現したいこと

tkinterで連続する座標データから角度を計算するような機能を持ったGUIを作成したいと考えていますが、タイトルの通りのエラーが出てしまいます。

発生している問題・エラーメッセージ

Traceback (most recent call last): File "/home/deepstation/PycharmProjects/tkinter/app.py", line 113, in <module> button2 = button_clicked(3, 2, 4) File "/home/deepstation/PycharmProjects/tkinter/app.py", line 75, in button_clicked data1 = pd.read_csv(a.csv, engine='python', names=('X', 'Y', 'accurancy', 'NaN')) AttributeError: 'int' object has no attribute 'csv'

該当のソースコード

python

1import os,sys 2import tkinter as tk 3from tkinter import * 4from tkinter import ttk 5from tkinter import filedialog 6from tkinter import messagebox 7from PIL import Image, ImageTk 8 9import pandas as pd 10import os 11import matplotlib.pylab as plt 12import numpy as np 13import csv 14 15root = tk.Tk() 16 17label = tk.Label(root, text="求める関節を選択") 18label.grid() 19 20# 参照ボタンのイベント 21# button1クリック時の処理 22def button1_clicked(): 23 fTyp = [("","*")] 24 iDir = os.path.abspath(os.path.dirname(__file__)) 25 dir = tk.filedialog.askdirectory(initialdir=iDir) 26 file1.set(dir) 27 file2 = file1.get() 28 os.chdir(file2) 29 30#参照ボタンの作成 31button1 = ttk.Button(root, text=u'参照', command=button1_clicked) 32button1.grid(row=1, column=3) 33 34# Frame1の作成 35frame1 = ttk.Frame(root, padding=10) 36frame1.grid() 37 38s = StringVar() 39s.set('ファイル>>') 40label1 = ttk.Label(frame1, textvariable=s) 41label1.grid(row=1, column=1) 42 43# 参照ファイルパス表示ラベルの作成 44file1 = StringVar() 45file1_entry = ttk.Entry(frame1, textvariable=file1, width=50) 46file1_entry.grid(row=1, column=2) 47 48def button_clicked(a, b, c): 49 f = open("angle" + '.csv', 'w') 50 writer = csv.writer(f, lineterminator='\n') 51 52 # データをリストに保持 53 csvlist = [] 54 55 # データの読み込み 56 data1 = pd.read_csv(a.csv, engine='python', names=('X', 'Y', 'accurancy', 'NaN')) 57 data2 = pd.read_csv(b.csv, engine='python', names=('X', 'Y', 'accurancy', 'NaN')) 58 data3 = pd.read_csv(c.csv, engine='python', names=('X', 'Y', 'accurancy', 'NaN')) 59 data_r = data1.reset_index() 60 61 # データからある列を指定して取得 62 x1 = data1['X'] 63 y1 = data1['Y'] 64 x2 = data2['X'] 65 y2 = data2['Y'] 66 x3 = data3['X'] 67 y3 = data3['Y'] 68 69 end = len(data1) 70 71 rad = np.zeros(end) 72 73 # 各インデックスでのラジアンの計算 74 for i in range(end): 75 vec1 = np.array([x2[i] - x1[i], y2[i] - y1[i]]) 76 vec2 = np.array([x3[i] - x1[i], y3[i] - y1[i]]) 77 cos = np.dot(vec1, vec2) / (np.linalg.norm(vec1) * np.linalg.norm(vec2)) 78 rad[i] = np.arccos(cos) 79 deg = np.rad2deg(rad) 80 81 # 出力 82 output_dir = file2 83 csvlist = [deg] 84 csvlist = np.array(csvlist).T 85 writer.writerows(csvlist) 86 87 # ファイルクローズ 88 f.close() 89 90frame2 = ttk.Frame(root, padding=(0, 5)) 91frame2.grid(row=1) 92 93button2 = button_clicked(3, 2, 4) 94 95rightelbow = ttk.Button(frame2, text='右肘', command=button2) 96rightelbow.grid(row=2, column=2) 97 98root.mainloop()

試したこと

GUIなので間違いを探すことが難しく、苦戦しています…

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

python3 ubuntu

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

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

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

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

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

tiitoi

2019/06/06 05:07

a.csv とかは "a.csv" の間違いでしょうか?
退会済みユーザー

退会済みユーザー

2019/06/06 05:14

a,b,cには任意の番号を代入します。例えば、button2をクリックした場合2.csv, 3.csv, 4.csvのデータで角度の計算が行われるようにしたいです。
guest

回答1

0

ベストアンサー

data1 = pd.read_csv(a.csv, ~data1 = pd.read_csv( '{}.csv'.format(a), ~ではないでしょうか?
b.csv, c.csvも同様。

投稿2019/06/06 05:07

編集2019/06/06 05:53
can110

総合スコア38266

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

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

退会済みユーザー

退会済みユーザー

2019/06/06 05:27

試してみましたが、 FileNotFoundError: [Errno 2] No such file or directory: 'a.csv'  というエラーが出てしまいます。 a,b,cにボタンごとに異なる数字を割り当てたいのですが、(例えばbutton2クリック時には2.csv, 3.csv, 4.csvが使用される、button3クリック時だったら5.csv, 6.csv, 7.csvなど)abcが文字として認識されてしまっているみたいです
can110

2019/06/06 05:52

であれば「data1 = pd.read_csv( '{}.csv'.format(a), ~」でよいかと思います。
退会済みユーザー

退会済みユーザー

2019/06/06 06:00

ありがとうございます。変数をファイル名に組み込むことが出来ました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問