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

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

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

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

Q&A

解決済

2回答

1080閲覧

複数ファイルで得られたリストを一つの表にしたい

Nari9113

総合スコア3

Python

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

0グッド

0クリップ

投稿2021/12/20 23:44

編集2021/12/21 04:40

前提・実現したいこと

下記コードで得られたファイル分のlistを一つの表としてファイル保存したいです
その際、列名も加えて出したいです
もしくはファイル分の得られたリストを一つのリストにまとめることが出来れば列数で区切る方法でできるかもしれません
どちらにしてもコードを調べて確認できなかったのでお力を貸してください!!

該当のソースコード(編集後)

Python

1from scipy.optimize import curve_fit 2import matplotlib.pyplot as plt 3import matplotlib.cm as cm 4import pandas as pd 5import numpy as np 6from scipy import signal 7import os 8from scipy.signal import find_peaks 9import glob 10import re 11 12lists=[] 13 14def process(datafile): 15 16---省略--- 17 18 lists.append(float(m.group(1))) 19 lists.append(V1) 20 lists.append(V2) 21 lists.append(V3) 22 23 n1=4 24 result1 = [lists[idx:idx + n1] for idx in range(0,len(lists),n1)] 25 pd.set_option('display.unicode.east_asian_width',True) 26 df1=pd.DataFrame(result1,columns=['Vmax','V1','V2','V3']) 27 print(df1) 28 with open('sample.txt', 'a') as f: 29 print(df1, file=f)

上記コード出力結果

Vmax V1 V2 V3 0 3.0 0.299352 -0.315534 0.614886 Vmax V1 V2 V3 0 3.0 0.299352 -0.315534 0.614886 1 1.5 -0.088712 -0.301286 0.212574 Vmax V1 V2 V3 0 3.0 0.299352 -0.315534 0.614886 1 1.5 -0.088712 -0.301286 0.212574 2 2.0 -0.079650 -0.326819 0.247169 Vmax V1 V2 V3 0 3.0 0.299352 -0.315534 0.614886 1 1.5 -0.088712 -0.301286 0.212574 2 2.0 -0.079650 -0.326819 0.247169 3 3.0 0.044492 -0.386038 0.430530 Vmax V1 V2 V3 0 3.0 0.299352 -0.315534 0.614886 1 1.5 -0.088712 -0.301286 0.212574 2 2.0 -0.079650 -0.326819 0.247169 3 3.0 0.044492 -0.386038 0.430530 4 3.5 -0.081171 -0.383873 0.302702

###再追記
惜しいところまで行っている気がするので編集させて頂きました
出力結果の最後の部分だけ取り出したいです、、、
###希望出力結果

Vmax V1 V2 V3 0 3.0 0.299352 -0.315534 0.614886 1 1.5 -0.088712 -0.301286 0.212574 2 2.0 -0.079650 -0.326819 0.247169 3 3.0 0.044492 -0.386038 0.430530 4 3.5 -0.081171 -0.383873 0.302702

のような表を出力したいです

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

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

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

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

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

y_waiwai

2021/12/21 00:08

ファイルを一つづつ読み込み、それをリストに展開し、それを複数行って一つの表を作ればいい、って回答になりますが、これのどれがわからないって話でしょうか
tatsu99

2021/12/21 00:13 編集

具体的にどんな表になれば良いのでしょうか。 ファイル分のlistの内容のサンプルと、出力結果である表の内容を提示していただけると、 良い回答がつくかと。質問は編可能です。質問に上記の内容を追記してください。
Nari9113

2021/12/21 00:32

y_waiwaiさん 1つ1つファイルを読み込み、関数で計算した結果(リスト)を得ることは出来ます。分からない部分はファイル1,2,3…に対してそれぞれのリスト1,2,3…があるとき、1行目ヘッダー,2行目リスト1,3行目リスト2,4行目リスト3…のような表を作るコードです。 説明不足ですみません、、 もう少し追記させていただきます!
Nari9113

2021/12/21 00:34

tatsu99さん リストサンプルと出力結果の提示を追記させていただきます 説明不足ですみません、、
guest

回答2

0

リストをどのようにして作っているかは不明ですので、サンプルとして
ls = [3.0,0.29935198881601,-0.31553397357163404,0.614885962387644]
としました。(リストの要素は全て数値の前提)
processでは1行分しか出力できないので、
ファイルのオープン、1行目の見出しの作成、ファイルのクローズはprocessの外で行ってます。
区切値文字はタブ区切りとしました。
全体のソースが提供されれば、もっと良い回答が得られるかも知れません。
参考になれば幸いです。

python3

1def process(data_file): 2 # lsはdata_fileから作られたリスト 3 ls = [3.0,0.29935198881601,-0.31553397357163404,0.614885962387644] 4 ls = list(map(lambda x: str(x),ls )) 5 ls.insert(0,data_file) 6 s = '\t'.join(ls)+'\n' 7 out_file.write(s) 8 9out_file = open("out.data",mode='w') 10title = ["ファイル名","項目1","項目2","項目3"] 11out_file.write('\t'.join(title)+'\n') 12data_file_list = ["ファイル1.txt","ファイル3.txt","ファイル3.txt"] 13for data_file in data_file_list: 14 process(data_file) 15 16out_file.close() 17

投稿2021/12/21 05:30

tatsu99

総合スコア5470

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

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

tatsu99

2021/12/21 05:34

すでに回答がでてますね。本回答は無視してください。
guest

0

自己解決

Python

1n1=4 2result1 = [lists[idx:idx + n1] for idx in range(0,len(lists),n1)] 3pd.set_option('display.unicode.east_asian_width',True) 4df=pd.DataFrame(result1,columns=['Vmax','V1','V2','V3']) 5print(df) 6with open('sample.txt', 'w') as f: 7 print(df, file=f)

コードを外付けすることでできました
ありがとうございました

投稿2021/12/21 04:46

Nari9113

総合スコア3

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

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

melian

2021/12/21 04:49

df.to_csv('sample.txt') とすればデータフレームの内容を CSV 形式で sample.txt に保存できますよ。
Nari9113

2021/12/21 05:13

確かにそのほうがExcelに貼り付けやすくもなるので助かります!! ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問