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

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

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

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

保存

保存(save)とは、特定のファイルを、ハードディスク等の外部記憶装置に記録する行為を指します。

Python

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

Q&A

解決済

2回答

1338閲覧

csvファイルに全ての内容を保存したい

taka12

総合スコア2

CSV

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

保存

保存(save)とは、特定のファイルを、ハードディスク等の外部記憶装置に記録する行為を指します。

Python

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

0グッド

0クリップ

投稿2020/09/26 05:00

発生している問題と実現したいこと

Python初心者なのですがPythonでJリーグの試合結果を取得しcsvファイルに保存したいと思い作成しました。
しかし試合結果の最後の一行しか保存されません。
printで表示されている全ての結果を保存したいです。

該当のソースコード

Python

1#データ取得 2url = "https://www.jleague.jp/match/search/?category%5B%5D=j1&club%5B%5D=gosaka&year=2019&section=" 3html = urlopen(url) 4soup = BeautifulSoup(html) 5gameTable = soup.find_all(class_="gameTable") 6 7#テキスト&リスト化 8for news_txt in gameTable: 9 news_txt = news_txt.text 10 line_txt= [line.strip("") for line in news_txt.splitlines() if line !=''] 11 csvlist = [] 12 csvlist.append(line_txt) 13 print(csvlist) 14 15#書き込み 16f = open("GOSAKA2019", "w") 17writecsv = csv.writer(f, lineterminator='\n',skipinitialspace=True) 18writecsv.writerows(csvlist) 19f.close()

発生している問題

printで表示できた物のうち最後の一行しかcsvファイルに保存されない。 printで表示されるもの [['G大阪', '2', '試合終了', '3', '横浜FM']] [['清水', '2', '試合終了', '4', 'G大阪']] [['G大阪', '2', '試合終了', '3', '名古屋']] ~~~~~~~~~~中略~~~~~~~~~~ [['G大阪', '2', '試合終了', '0', '仙台']] [['G大阪', '4', '試合終了', '1', '松本']] [['浦和', '2', '試合終了', '3', 'G大阪']] csvに保存されるもの 浦和, 2, 試合終了, 3, G大阪

もしかしたら角括弧の後ろにカンマがついていないのが問題かと思いましたが、カンマのつけ方が分からないので試せていません。

ご教授いただければ幸いです。よろしくお願いします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

ファイルに書き込むタイミングを変えれば良いと思います。

Python

1f = open("GOSAKA2019", "w") 2writecsv = csv.writer(f, lineterminator='\n',skipinitialspace=True) 3 4for news_txt in gameTable: 5 news_txt = news_txt.text 6 line_txt= [line.strip("") for line in news_txt.splitlines() if line !=''] 7 csvlist = [] 8 csvlist.append(line_txt) 9 print(csvlist) 10 writecsv.writerows(csvlist) 11 12f.close()

投稿2020/09/26 05:07

meg_

総合スコア10760

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

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

taka12

2020/09/26 05:14

解決しました! ありがとうございます!
guest

0

csvlistを作る際に、残念ながら、1試合ごとにcsvlistを空にしてしまっています。
csvlistを作る部分を以下のように変更してください。

Python

1csvlist = [] 2for news_txt in gameTable: 3 news_txt = news_txt.text 4 line_txt= [line.strip("") for line in news_txt.splitlines() if line !=''] 5 csvlist.append(line_txt) 6print(csvlist)

投稿2020/09/26 05:50

toast-uz

総合スコア3266

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問