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

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

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

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

Q&A

解決済

1回答

3698閲覧

列の全ての数の小数点以下を揃えたいです

matya

総合スコア16

Python

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

0グッド

0クリップ

投稿2019/06/08 23:37

前提・実現したいこと

特定の数値だけでなく、列に含まれる数値全てを対象に小数点の桁を揃えたいです。

やりたいこと全体としては、csvファイルを読み込み、
列ごとに値を取得して、一列に書かれているものを一行に書き出したいです。(縦横を入れ替えます)

形式を変える過程で、小数点の桁も揃えたいのですが、それがうまくいっていません。

発生している問題

小数点以下第2位に揃えたつもりが、printすると

(78.71225528, '2f') (79.18972624, '2f') (79.23910929, '2f') (78.03111468, '2f')

となります。

該当のソースコード

python

1import csv 2import os 3import numpy as np 4 5path = 'path_a' 6filelist = [] 7# os.makedirs(path + "/" + "縦横入替後") 8path2 = path + "/" + "縦横入替後" 9 10for c in os.listdir(path): 11 if os.path.isfile(os.path.join(path, c)): 12 filelist.append(c) 13 14temp = [] 15for f in filelist: 16 reader = csv.reader((open(path + "/" + f, "r", encoding="utf_8")), delimiter=',') 17 for row in reader: 18 temp.append(row) 19 20all = np.array(temp) 21float_t = all[:, 0] 22 23temp2 =[] 24for i in float_t: 25 temp2 = format((float(i), '2f')) 26 print(temp2) 27 28 29with open(path2 + "/" + f + "_after_replace.csv","w",newline="") as table: #縦横を入れ替えたものを書き出します 30 writer = csv.writer(table, delimiter=',') 31 writer.writerow(temp2) 32 33

試したこと

'2f'が文字列として認識されているのかなと思ったのですが、どうすればよいのかわかっていません。また、下記でもやってみたのですが、うまくいきませんでした。

cumulative_r = '{:.2f}'.format(cumulative)

教えていただけますと幸いです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

小数点以下第2位に揃えたつもりが、printすると ... となります。

二重に間違えて居ます。

  • 不要な括弧
  • フォーマット文字列の誤り

Python

1>>> val = 3.141592 2>>> format((val, '2f')) # format関数にタプルを渡している。 3"(3.141592, '2f')" 4>>> format(val, '2f') # 小数点以下2桁にしたいのなら、 5'3.141592' 6>>> format(val, '.2f') # ドットの後に2と書く。 7'3.14'

CSVを読み取るときはnp.loadtxt、吐き出すときはnp.savetxtが使えます。
以下、入力が一ファイルであるときの簡単なサンプルです。

Python

1import numpy as np 2 3 4arr = np.loadtxt('in.csv', delimiter=',') 5arr = arr[:, 0][np.newaxis] 6 7np.savetxt('out.csv', arr, delimiter=',', fmt='%.2f')

投稿2019/06/09 00:29

LouiS0616

総合スコア35660

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

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

matya

2019/06/09 11:06

LouiS0616さん、早速回答してくださり、ありがとうございました。 二重で間違っていたのですね。訂正したところ正しく動くようになりました。 助かりました。ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問