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

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

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

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python 3.x

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

Q&A

解決済

3回答

1350閲覧

特殊な指数表記を含むcsvファイルの読み込み

daily_999

総合スコア3

NumPy

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python 3.x

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

0グッド

0クリップ

投稿2023/03/09 08:12

実現したいこと

特殊な指数表記を含むcsvファイルをNumpy loadtxtで読込みたい

前提

当方が扱っている解析系プログラムのインプットファイルでは、節点座標値が指数表記の場合以下の右側のように記載するルールとなっています。
2.342E-12 → 2.342-12
なお、インプットファイルには指数と小数点表記が混在しています。

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

インプットファイルの節点座標値をcsv形式に変換し、Numpyライブラリのloadtxtで配列Nodeに読み込ませたいのですが、上記指数表記が邪魔をしているようで成功しません。

ValueError: could not convert string '2.342-12' to float64 at row 226, column 3.

該当のソースコード

Python

1import numpy as np 2Node = np.loadtxt('test.csv',dtype='float',delimiter=',',encoding="utf-8_sig")

試したこと

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

Python3, Numpyを使っています。
ご教示いただけますと幸いです。宜しくお願い致します。

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

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

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

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

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

guest

回答3

0

ベストアンサー

test.csv

csv

12.342-12,123.456+6

python

1import re 2import numpy as np 3 4Node = np.loadtxt('test.csv',dtype='float',delimiter=',',encoding="utf-8_sig", 5 converters=lambda i: re.sub(r'(?<=\d)([+-])', r'E\1', i)) 6 7print(Node) 8 9# [2.34200e-12 1.23456e+08]

投稿2023/03/09 08:30

melian

総合スコア19798

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

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

daily_999

2023/03/09 10:26

ご回答ありがとうございます。参考にさせていただきます。
daily_999

2023/03/09 11:25

(?<=\d) この正規表現について、いろいろ検索したのですが<=がわからず、お手数ですがご教示いただけないでしょうか。
daily_999

2023/03/09 11:56

ありがとうございました。よく理解できました。
guest

0

test.csvを読んで、普通の表記にして、別ファイルに書き込むという前処理をすれば良いかと思います。
お書きのことだけであれば、単に-E-に置換する。

-12-3のような数値もあるなら正規表現で。

投稿2023/03/09 08:28

otn

総合スコア84555

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

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

daily_999

2023/03/09 10:26

ご回答ありがとうございます。参考にさせていただきます。
guest

0

まずはstrで読込んで、各要素に対して正規表現でEを付加してfloatに変換すればよいかと思います。

Python

1import numpy as np 2from io import StringIO 3import re 4 5def conv(v): 6 v = re.sub(r'(\d)-(\d)', r'\1E-\2', v) 7 return float(v) 8f = np.vectorize(conv) 9 10Node = np.loadtxt(StringIO('1,1.2,-1,2.342-12,2'), dtype=str, delimiter=',') 11Node = f(Node) 12print(Node) # [ 1.000e+00 1.200e+00 -1.000e+00 2.342e-12 2.000e+00]

投稿2023/03/09 08:25

can110

総合スコア38266

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

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

daily_999

2023/03/09 10:26

ご回答ありがとうございます。参考にさせていただきます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問