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

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

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

Jupyter (旧IPython notebook)は、Notebook形式でドキュメント作成し、プログラムの記述・実行、その実行結果を記録するツールです。メモの作成や保存、共有、確認などもブラウザ上で行うことができます。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

MacOS(OSX)

MacOSとは、Appleの開発していたGUI(グラフィカルユーザーインターフェース)を採用したオペレーションシステム(OS)です。Macintoshと共に、市場に出てGUIの普及に大きく貢献しました。

Q&A

解決済

1回答

15863閲覧

AttributeError: 'NoneType' object has no attribute 'find_all'対処法について

M.Faraday

総合スコア13

Jupyter

Jupyter (旧IPython notebook)は、Notebook形式でドキュメント作成し、プログラムの記述・実行、その実行結果を記録するツールです。メモの作成や保存、共有、確認などもブラウザ上で行うことができます。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

MacOS(OSX)

MacOSとは、Appleの開発していたGUI(グラフィカルユーザーインターフェース)を採用したオペレーションシステム(OS)です。Macintoshと共に、市場に出てGUIの普及に大きく貢献しました。

0グッド

0クリップ

投稿2019/01/12 13:01

前提・実現したいこと

Jupyternotebookでnetkeiba.comの以下のURLから勝率や単勝回収率が記載されたテーブルをスクレイピングしてきて、csvに吐き出したいと思っています。
https://race.netkeiba.com/?pid=data_list&id=c201906010311&mode=distance&cid=1

実装中に以下のエラーメッセージが発生しました。
AttributeError: 'NoneType' object has no attribute 'find_all'

発生している問題・エラーメッセージ

--------------------------------------------------------------------------- AttributeError Traceback (most recent call last) <ipython-input-17-0325cb6c9893> in <module>() 50 51 if __name__ == '__main__': ---> 52 main() <ipython-input-17-0325cb6c9893> in main() 35 table = soup.find('table', {'id':'table_sort_back', 36 'class': 'data_main_tb_01 data_table_01 nk_tb_common'}) ---> 37 rows = table.find_all("tr") 38 39 csvFile = open("n1.csv", 'wt', newline = '', encoding = 'utf-16')#utf-8だと文字化け AttributeError: 'NoneType' object has no attribute 'find_all'

該当のソースコード

import requests import csv import urllib from bs4 import BeautifulSoup from urllib.parse import urljoin def main() -> None: url = 'https://race.netkeiba.com/?pid=data_list&id=c201906010311&mode=distance&cid=1' USER = "XXXXXX@gmail.com"(ダミーです) PASS = "YYYYYYYYY"(ダミーです) login_info = { "login_id":USER, "pswd":PASS, } session = requests.session() url_login ="https://regist.netkeiba.com/account/?pid=login&action=auth" ses = session.post(url_login, data=login_info) res = session.get(url) soup = BeautifulSoup(res.content, "html.parser") print(soup.text) table = soup.find('table', {'id':'table_sort_back', 'class': 'data_main_tb_01 data_table_01 nk_tb_common'}) rows = table.find_all("tr") csvFile = open("netkeiba.csv", 'wt', newline = '', encoding = 'utf-16') writer = csv.writer(csvFile, dialect='excel', delimiter='\t', quoting=csv.QUOTE_ALL) try: for row in rows: csvRow = [] for cell in row.find_all(['td', 'th', 'a']): csvRow.append(cell.get_text().strip('\n')) writer.writerow(csvRow) finally: csvFile.close() if __name__ == '__main__': main()

試したこと

ちなみにですが、
url = 'http://db.netkeiba.com/horse/result/2011102151/'
とした場合、
table = soup.find('table', {'class': 'db_h_race_results nk_tb_common'})
とするとエラーは出ずにうまくいきます。

補足情報(FW/ツールのバージョンなど)

環境は以下です
MAC OS High Sierra バージョン10.13.6
Jupyter notebook 5.0.0

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

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

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

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

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

guest

回答1

0

ベストアンサー

---> 37 rows = table.find_all("tr")
AttributeError: 'NoneType' object has no attribute 'find_all'

このエラーが出るときのtable の値を確認してみましょうよ

投稿2019/01/12 13:12

y_waiwai

総合スコア87719

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

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

M.Faraday

2019/01/12 13:43

len(table)が0になるということはテーブルが取れてないってことでしょうか? ソースをどう修正すればテーブルを取得できますでしょうか?
y_waiwai

2019/01/12 13:51

コードを詳細には読んでませんが、findメソッドの戻り値であれば、その条件のテーブルが存在しなかった、あるいは何かエラーが起きた、ということじゃないかと。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問