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

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

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

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

Q&A

解決済

2回答

10331閲覧

1次元の集計結果をCSVに出力させたい

midsum0323

総合スコア40

Python

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

0グッド

0クリップ

投稿2017/07/20 08:45

編集2017/07/23 01:52

###前提・実現したいこと
1カラム内にある要素の個数を数え、その結果をCSVに出力させたいです。
例えば
df内のカラムPが
A
B
A
B
C
だとすると、
A 2
B 2
C 1
という結果をCSVに出力させたいです。
できれば指定のディレクトリに出力させたいです。

###該当のソースコード
要素内の個数計算
from collections import Counter
df‗kekka = Counter(df["P"])

CSV出力
def print_data_table(df_kekka):
header = [h.get('name') for h in df_kekka.get('P')]
output = [header] + df_kekka.get('rows',[])
print(output)
with open('C:\Users\~略~\結果.csv','wt') as f:
writer = csv.writer(f,lineterminator='\n')
writer.writerows(output)

###試したこと
from collections import Counter
df‗kekka = Counter(df["P"])
で求める値は計算できたが、

import csv
os.chdir("C:\Users\~略")
df_kekka.to_csv("結果.csv")
の結果は以下のようになる。

AttributeError: 'Counter' object has no attribute 'to_csv'

###補足情報(言語/FW/ツール等のバージョンなど)
.6.0 |Anaconda 4.3.0 (64-bit)| (default, Dec 23 2016, 11:57:41) [MSC v.1900 64 bit (AMD64)]
In [ ]:

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

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

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

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

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

guest

回答2

0

ベストアンサー

Counter(...)の結果はDataFrameではないため、提示のエラーとなります。

value_counts()を使うと簡潔にできます。
また、出力ファイル名をフルパスで指定すれば、任意のディレクトリに出力できます。

Python

1import pandas as pd 2import os 3 4df = pd.DataFrame([["A"],["B"],["A"],["A"],["B"],["C"]],columns=['P']) 5df_kekka = df['P'].value_counts() 6print(df_kekka) 7 8# 出力ファイル名をフルパスで指定する 9path = os.path.join( 'C:\\Users\\~略', '結果.csv') 10df_kekka.to_csv( path)

投稿2017/07/20 09:08

can110

総合スコア38266

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

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

midsum0323

2017/07/23 01:49

お二方、ありがとうございました!
guest

0

元データはのdf というのは pandas.DataFrame と言う認識でよろしいでしょうか?

であれば Series.value_count()を使うと良いと思います。

Python

1df = pd.DataFrame({'DATA':['A','B','A','C','A','C','D','B','A','A']}) 2df['DATA'].value_counts().to_csv("count.csv")

投稿2017/07/20 09:22

編集2017/07/21 10:52
magichan

総合スコア15898

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

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

magichan

2017/07/20 09:23 編集

あっ、かぶりましたね。スミマセン。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問