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

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

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

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

333閲覧

2桁の整数が1桁×2になってしまう

noggi

総合スコア8

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/08/05 16:45

独学初心者の質問で申し訳ありませんがよろしくお願いします。

実験の数値を.xlsxに記録していくコードを書いています。

最新の実験の数値を過去のものと合計する処理はできているのですが、32が3と2に別れて計算されてしまいます。

ファイルに書き込んだり、読み込んだりする際のint()とかstr()のリストの変換の際の処理がうまくできていないのだと考えられます。

記録する上で、ゆくゆく日付等も入れたいので、改行を入れて記録しています。

お知恵を拝借できたらと思いますので何卒よろしくお願いします。

Python

1 2#dis=floatのリストです 3dis = [10.0, 12.5, 10.2] 4a = sum(dis) 5easy = round(a) #=32 6 7 8#.xlsxに上書き保存。 9file = open('Moving.xlsx', 'a') 10file.write(str(easy)+"\n") 11file.close() 12 13#もう一回ファイルを開いて合計。これまでの.xlsxのデータを5,5とします。 14with open("Moving.xlsx", "r") as p: 15 k = list(str(p.read()).replace("\n", "")) 16 goukei = sum(list(map(int, k) 17 print(str(goukei)+"cm”) 18

実行結果・・5+5+3+2=15
期待する実行結果・・5+5+32=42

最初の実行結果は5532でしたが、ここまでは何とかできました。

「そもそもこうしたらいい」的な大きな変更でも大丈夫です。よろしくおねがいします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

問題の根本は文字列をlistしたらどうなるか?です。
print(list("123456"))
とやってみたら分かりますが、1文字づつ区切られたリストになります。
なので当然3と2が分かれて別々に足されます(手元では33でしたが・・・)

で、やりたい事が何かというと、ファイルの1行をint型の1要素としたリストを作ってそれを計算したいのですよね?
であれば、read()で一括取得した時は改行文字で分割してリストにすればいい事になりますが・・・最後に改行だけの行があるので話しが長くなるのでやめましょう。。

他にファイルの読み込みはreadline()とreadlines()があります。
詳細はググってください。

素直にやるならreadlines()でファイル全部をリストとして読み込み、一つ一つの要素をint型にして新しいリストに追記していくのが一番分かりやすいでしょう。

python

1with open("Moving.xlsx", "r") as p: 2 nums = [] 3 for item in p.readlines(): 4 nums.append(int(item)) 5 # nums = [int(item) for item in p.readlines()] 上3行の内包表記 6 print(f"{sum(nums)}cm")

あと、現在読み書きしているファイルはただのテキストファイルですので、拡張子は.txtがいいと思います。
また、複雑な事をする場合はcsvやエクセルファイルを扱えるライブラリがあるのでそれを使うとよいでしょう。

投稿2021/08/05 17:50

編集2021/08/05 17:59
udon-ken

総合スコア657

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

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

noggi

2021/08/06 05:21

バッチリできました。ありがとうございました!readlines、見たことはありましたが、おかげさまで使い方が具体的にわかりました。.txtのアドバイスまでいただき、本当にありがたいです。勉強になりました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問