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

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

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

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

Beautiful Soup

Beautiful Soupは、Pythonのライブラリの一つ。スクレイピングに特化しています。HTMLデータの構文の解析を行うために、HTMLタグ/CSSのセレクタで抽出する部分を指定することが可能です。

Python

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

Q&A

解決済

2回答

667閲覧

csvファイル書き出し時ファイル名に変数を使い、ループ複数のファイルを書き出す方法をご教授ください。

Ringopan19

総合スコア36

CSV

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

Beautiful Soup

Beautiful Soupは、Pythonのライブラリの一つ。スクレイピングに特化しています。HTMLデータの構文の解析を行うために、HTMLタグ/CSSのセレクタで抽出する部分を指定することが可能です。

Python

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

0グッド

0クリップ

投稿2022/01/16 10:25

下記のコードにより、指定したページの要素をループで取得し、変数を名前にしたcsvファイルを複数書き出したいのですがエラーが出てしまいます。
クソ雑魚で申し訳ございませんが。対処法をご存知の方がいましたらご教授いただけますと幸いです。

自分が書いたコード↓

from time import sleep
from bs4 import BeautifulSoup
import requests
import pandas as pd

url = "https://alert.shop-bell.com/books/magazine/{}"

d_list = []

for i in range(1, 10):
print('d_listの大きさ:', len(d_list))
target_url = url.format(i)
print(target_url)

r = requests.get(target_url) sleep(1) soup = BeautifulSoup(r.text) comics = soup.select('table[id="reflow"] > tbody > tr') for comic in comics: title = comic.find('a').text author = comic.find('span', attrs={'class': 'muted'}).text #release_date = comic.find('td', attrs={'class': 'srpLatest'}).text.split('巻')[1] release_date = comic.find('td', attrs={'class': 'srpLatest'}).text if '巻' in release_date: release_date = release_date.split('巻')[1] d = {'title': title, 'author': author, 'release_date': release_date} d_list.append(d) df = pd.DataFrame(d_list) name = soup.find("h2") df.to_csv(name + '.csv',encoding="utf-8-sig")

from pprint import pprint
pprint(d_list, width=50, sort_dicts=False)

出てきたエラー↓

TypeError Traceback (most recent call last)
<ipython-input-60-7edcfaec4a55> in <module>
28 df = pd.DataFrame(d_list)
29 name = soup.find("h2")
---> 30 df.to_csv(name + '.csv',encoding="utf-8-sig")
31
32 from pprint import pprint

TypeError: unsupported operand type(s) for +: 'Tag' and 'str'

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

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

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

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

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

guest

回答2

0

「TypeError: unsupported operand type(s) for +: 'Tag' and 'str'」
Tagとstr(文字列)をそのまま+で連結しようとしているのでエラーになっています。

python

1df.to_csv(name.text + '.csv',encoding="utf-8-sig")

とした場合いかがでしょうか。

投稿2022/01/16 10:56

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

guest

0

自己解決

下記の部分を↓
df.to_csv(name + '.csv',encoding="utf-8-sig")

.textをつけた修正したらうまくいきました。
df.to_csv(name.text + '.csv',encoding="utf-8-sig")

qnoir様と言う方にご回答いただき問題を解決することができましたが、
どうやら下記エラーは↓
「TypeError: unsupported operand type(s) for +: 'Tag' and 'str'」
Tagとstr(文字列)をそのまま+で連結しようとしているのでエラーになっているようなので、
変数nameに.textをつけてstr(文字列)にしてあげたからうまく行ったみたいです。

データ型などの知識がなく、何と何だったら連結したらいいのかもよくわからないクソ雑魚プログラマーの僕からしたら神でした。これからもどうぞよろしくお願いいたします。しゃーららっらっら

投稿2022/01/16 11:34

Ringopan19

総合スコア36

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問