現在、時間を取得しその時間をCSVファイルに記録するプログラムを作成しています。
作成したプログラムの一部が以下に示す通りです。
python
1name = input() 2cnvtime2 = time.strptime(now2) 3logout = time.strftime("%Y/%m/%d %H:%M", cnvtime2) 4t = time.time() 5total = [] 6out_time = {"A時間":logout, "B時間":t + str("時間")} 7total.append(out_time) 8exists = Path("./記録/" + str(name) + ".csv").exists() 9with open("./記録/" + str(name) + ".csv","a") as f: 10 writer = csv.DictWriter(f, fieldnames=['A時間', 'B時間']) 11 if not exists: 12 print("ファイルを作成します") 13 writer.writeheader() # ヘッダーを書き込む。 14 writer.writerows(total)
上記のプログラムを実行したところ、以下のようなエラーが発生してしまいました。
ValueError: time data 'Tue Jun 11 20:56:56 2019' does not match format '%a %b %d %H:%M:%S %Y'
そこで、以下のサイトを参考に修正しました。
参考URL
また、修正したプログラムが以下に示す通りです。
python
1name = input() 2locale.setlocale(locale.LC_ALL, (None,None)) 3cnvtime2 = time.strptime(now2) 4logout = time.strftime("%Y/%m/%d %H:%M", cnvtime2) 5t = time.time() 6total = [] 7out_time = {"A時間":logout, "B時間":t + str("時間")} 8total.append(out_time) 9exists = Path("./記録/" + str(name) + ".csv").exists() 10with open("./記録/" + str(name) + ".csv","a") as f: 11 writer = csv.DictWriter(f, fieldnames=['A時間', 'B時間']) 12 if not exists: 13 print("ファイルを作成します") 14 writer.writeheader() # ヘッダーを書き込む。 15 writer.writerows(total)
上記のプログラムを実行したところ、value errorは消えたのですが、以下の新しいエラーが出てきてしまいました。
UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-3: ordinal not in range(128)
ネットの記事等みてみたのですが、型が違うため記入できないということまではなんとなくわかったのですが、解決方法がわからない状態です。数値型を文字列型にする方法で型を変えようとしてもダメでした。上記のエラーについての解決策を教えていただけると助かります。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/06/11 14:16