🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Python

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

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

Q&A

解決済

2回答

881閲覧

python 辞書型の書き込みについて

TheBullchannel

総合スコア33

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Python

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

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

0グッド

0クリップ

投稿2019/10/29 04:49

編集2019/10/29 05:20

d = {"a":[], "b":[]}

上記のような辞書型のデータをcsvに書き込み、

a b
1000 2355
2554 4544
4445 7556
4655
7755

例えば、上記のようなデータを作成したいです。

with open('/python/rads.csv', 'w') as f:
writer = csv.DictWriter(f, ['a', 'b'])
writer.writeheader()
writer.writerows([d])

としたところ、保存はできましたが、1つのセルにいくつもの数字が入ってしまい大変読みにくくなってしまいました。
上記のように、1つのセルにデータを1つ入れるためにはどのように記述すればよいのでしょうか。

加えて、set関数を使って、aとbをから重複した数字を抜き出したいのですが、うまくできません。
set(d["a"]) & set(d["b"])
という記述はどこが間違っているのでしょうか。

よろしくお願いします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

dictに含まれている各配列の長さが同じであるならば、Pandasを使って

Python

1import pandas as pd 2import numpy as np 3 4d = {'a' : [1000,2554,4445,4655,7755],'b':[2355,4544,7556,np.nan,np.nan]} 5 6pd.DataFrame(d).to_csv('out.csv')

でよいのではと思います。

出力ファイル(out.csv)

csv

1,a,b 20,1000,2355.0 31,2554,4544.0 42,4445,7556.0 53,4655, 64,7755,

各配列の長さが違うのであれば、列毎にSeries化して結合することででDataFrameを作ることで、同じ方法を使うことができます。

Python

1import pandas as pd 2 3d = {'a' : [1000,2554,4445,4655,7755],'b':[2355,4544,7556]} 4 5df_a = pd.Series(d['a'], name='a') 6df_b = pd.Series(d['b'], name='b') 7pd.concat([df_a, df_b], axis=1).to_csv('out.csv')

投稿2019/10/29 06:34

magichan

総合スコア15898

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

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

TheBullchannel

2019/10/29 14:18

pandasを使うと、aとbの長さが違うという様なエラーが出ていたので、できないものだと思っていましたが、このようなやり方もあるのですね! 勉強になりました。ありがとうございました。
guest

0

要求するようなCSVを作成したいということであれば、dは、このような内容のリストになっている必要があります。

python

1d = [{'a': 1000, 'b': 2355}, 2 {'a': 2554, 'b': 4544}, 3 {'a': 4445, 'b': 7556}, 4 {'a': 4655, 'b': ''}, 5 {'a': 7755, 'b': ''}]

値が無い列のbの値を空白にしましたが、bそのものが無くてもいいです。

なので、

  • このような形のデータを用意する
  • もとのデータをこのような形に変形する処理を作る
  • 書込みのループの中でデータを生成する

などの対応をすればよいのではないかと思います。

投稿2019/10/29 05:55

TakaiY

総合スコア13767

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

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

TheBullchannel

2019/10/29 14:18

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問