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

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

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

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

Q&A

2回答

330閲覧

テキストファイルへ一部のデータしか保存されない。

1mzmk

総合スコア42

Python

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

0グッド

0クリップ

投稿2019/04/04 17:51

私は、あるjsonファイルを使用しています。
私のjsonファイルは、下のURLのjsonファイルでワインについてのレビューについてのデータで、多くの種類のワインのレビューについてリストとして記載されています。
'https://github.com/tulip-lab/sit742/raw/master/Assessment/2019/data/wine.json'

行には”country”,"variety", "price", "point", "description"などの項目があります。
私のjsonファイルは下のような表になります。(1行が1レビューになってます。)

イメージ説明
このjsonファイルの”description”の列に含まれる単語でTF-IDF>0.4となるものを下のコードで出力しました。

python

1import pandas as pd 2from nltk.tokenize import RegexpTokenizer 3 4df = pd.read_json("wine.json") 5df2 = df.dropna(subset=['points','price']) 6with open('stopwords.txt') as f: 7 stop_words = f.read().splitlines() 8stop_words = set(stop_words) 9 10tokenizer = RegexpTokenizer(r"\w+(?:[-']\w+)?") 11 12def f(s): 13 tokens = tokenizer.tokenize(s) 14 return " ".join(word for word in tokens if word not in stop_words) 15 16df2["description"] = df2["description"].map(f) 17df2.to_json("result.json") 18 19df6 = pd.read_json("result.json") 20 21df7 = df2["description"] 22 23df8 = df6.query('variety == "Shiraz"') 24 25df9 = df8["description"] 26df9 27 28from sklearn.feature_extraction.text import TfidfVectorizer 29tfidf = TfidfVectorizer(analyzer='word', stop_words = 'english') 30 31vecs = tfidf.fit_transform(df9) 32 33TF_IDF = vecs.toarray() 34print(TF_IDF[TF_IDF>0.4]) 35 36import numpy as np 37 38TF_IDF = vecs.toarray() 39terms = tfidf.get_feature_names() 40for idx, word in zip(*np.where(TF_IDF> 0.4)): 41 print("INDEX:{}, WORD:{}, TF-IDF:{}".format(idx, terms[word], TF_IDF[(idx,word)]))

上のコードを出力すると、下のようなTF-IDF>0.4の単語の一覧とTF-IDFのそれぞれの値が出力されました。

イメージ説明
これを'key_Shiraz.txt'という名前のテキストファイルに保存するために下のコードを入力しました。

pyton

1df10 = print("INDEX:{}, WORD:{}, TF-IDF:{}".format(idx, terms[word], TF_IDF[(idx,word)])) 2 3text = df10 4with open('key_Shiraz.txt','w') as f: 5 f.write(text)

しかし、'key_Shiraz.txt'のファイルには下の写真のようにTF-IDF>0.4の単語の一覧とTF-IDFのそれぞれの値が出力されておらず、一つの行しか保存されていませんでした。
イメージ説明

私が出力したすべてのTF-IDF>0.4の単語の一覧とTF-IDFのそれぞれの値を”key_Shiraz.txt”
に保存するためにはdf10をどのように定義すればよろしいのでしょうか。

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

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

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

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

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

guest

回答2

0

提示のコードは1行を出力するようなコードなので、そういう結果になりますね
複数行保存させたいならそのようにコードを書く必要があります

投稿2019/04/04 21:19

y_waiwai

総合スコア87747

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

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

1mzmk

2019/04/05 07:12

その複数行保存させるためのコードはどのように書くことができるのでしょうか? お願いします。
guest

0

printがちゃんとできているなら、そこでファイルへの書き込みを同時にやってしまえば済むのでは。

投稿2019/04/05 06:16

KojiDoi

総合スコア13671

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

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

1mzmk

2019/04/05 07:36

TF_IDF = vecs.toarray() terms = tfidf.get_feature_names() for idx, word in zip(*np.where(TF_IDF> 0.4)): text = print("INDEX:{}, WORD:{}, TF-IDF:{}".format(idx, terms[word], TF_IDF[(idx,word)])) with open('key_Shiraz.txt','w') as f: f.write(text) と書くということでしょうか?
KojiDoi

2019/04/05 10:53

openは予め別のところで行って開きっぱなしにしておかないとまずいでしょうね。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問