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

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

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

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

Q&A

解決済

1回答

743閲覧

Javascriptを使ったウェブページの途中からスクレイピングができなくなる

youkiti

総合スコア11

Python 3.x

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

0グッド

0クリップ

投稿2017/11/30 12:45

編集2017/11/30 13:04

Python 3.4です。

Javascriptを使ったウェブページのスクレイピングをしようとしているのですが、ページ途中から抽出ができなくなりました。

サンプルURL
https://www.crd.york.ac.uk/prospero/display_record.php?RecordID=26939

Stage of review
の次の<p></p>を抽出しようとしています。

Countryまでは抽出できるのですが、なぜかStage of review以下の全てが読めず、空白のみが返ってきます。

import lxml.html from selenium import webdriver url="https://www.crd.york.ac.uk/prospero/display_record.php?RecordID=26939" driver = webdriver.PhantomJS(executable_path='C:/Users/XX/phantomjs-2.1.1-windows/bin/phantomjs.exe') driver.get(url) root = lxml.html.fromstring(driver.page_source) country = root.xpath('string(//h1[contains(text(),"Country")]/following-sibling::p[1])') #ここから上手く動かない stage= root.xpath('string(//h1[contains(text(),"Stage of review")][1]/following-sibling::p[1])') driver.quit()

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

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

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

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

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

mkgrei

2017/11/30 12:58

一応、JavascriptはJavaと関係のない言語なので、タイトルをJavascriptにした方がわかる人が答えてくれる可能性が高いです。
youkiti

2017/11/30 13:04

ありがとうございます。
guest

回答1

0

ベストアンサー

不思議ですね。
うまくいかないことを再現しました。

Stage of reviewが2以上マッチングするのでCountryよりも凝ったことをしているようですね。
はっきりとはわかりませんが、PhantomJSのバグかもしれません。
最近PhantomJSは廃れ始めているようなのです。
https://www.infoq.com/jp/news/2017/04/Phantomjs-future-uncertain

実はheadlessの操作はChromeでできるようになりました。
そこで、Chromeのwebdriverを使ったところ、問題なく実行されました。

信条上の都合でGoogle Chromeは使用できないのでないならば、そちらに切り替えることをおすすめします。
これ以上はPhantomJSのプロにおまかせです。

投稿2017/11/30 13:40

mkgrei

総合スコア8560

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

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

youkiti

2017/11/30 21:30

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問