2016-12-29 10 views
1

私はウェブサイトから動的コンテンツを取得しようとしています。ウェブサイトからjavascript動的コンテンツを取得する方法

私は治療でコンテンツを取得しようとしました。しかし、コンテンツはjsファイルで読み込まれています。だから、テキストには入りません。

次に、このためにセレンをインストールしましたが、今はセッションエラーが発生していません。

たとえば、これはコンテンツを取得しようとしているページです。

http://www.hepsiburada.com/fox-fitness-new-target-70e-2-5-hp-motorlu-masajli-kosu-bandi-hediye-secenekleriyle-p-SPORKONKSBFOX0081?magaza=Finspor

そして、私はこのウェブサイトのためにこれを試してみました。

item = ProductItem 
     name = response.css('h1.product-name::text').extract_first() 
     price = response.css('span[id=offering-price] > span::text').extract_first() 
     xpath = response.xpath('/html/head/script[17]') 
     data = xpath.re(" = (\{.+\})") 
     print(data) 

これは私が取得しようとしているコンテンツです。

var utagData = {"merchant_names":["Finspor"],"new_site":"new","order_store":"Finspor","order_currency":"TRY","page_domain":"www.hepsiburada.com","page_language":"tr-TR","page_site_name":"Hepsiburada","page_site_region":"tr","site_type":"desktop","page_type":"pdp","page_name":"Product Detail","category_path":"/product/spor-outdoor/spor-fitness/fitness-kondisyon/kosu-bantlari/sporkonksbfox008/","page_title":"Fox Fitness New Target 70E 2.5 Hp Motorlu, Masajlı Koşu Fiyatı","page_url":"http://www.hepsiburada.com/fox-fitness-new-target-70e-2-5-hp-motorlu-masajli-kosu-bandi-hediye-secenekleriyle-p-SPORKONKSBFOX0081?magaza=Finspor","page_referring_url":"http://www.hepsiburada.com/gunun-firsati-teklifi?element=1","page_query_string":["magaza=Finspor"],"is_canonical":"1","canonical_url":"http://www.hepsiburada.com/fox-fitness-new-target-70e-2-5-hp-motorlu-masajli-kosu-bandi-hediye-secenekleriyle-pm-sporkonksbfox008","product_prices":["999.00"],"product_unit_prices":["999.00"],"product_brands":["Fox Fitness"],"product_brand":"Fox Fitness","product_skus":["SPORKONKSBFOX0081"],"product_ids":["sporkonksbfox008"],"product_top_5":["sporkonksbfox008"],"product_names":["Fox Fitness New Target 70E 2.5 Hp Motorlu, Masajlı Koşu Bandı (Hediye Seçenekleriyle)"],"product_category_ids":["19249"],"product_categories":["kosu-bantlari"],"shipping_type":["super-hizli"],"product_quantities":["1"],"product_barcodes":["8691128100776"],"product_barcode":"8691128100776","product_name_array":"Fox Fitness New Target 70E 2.5 Hp Motorlu, Masajlı Koşu Bandı (Hediye Seçenekleriyle)","merchant_ids":["95df0e3483104fc1a16cca6e38bc45cc"],"order_subtotal":["999.00"],"category_id_hierarchy":"60001546 > 2147483635 > 353045 > 19249","category_name_hierarchy":"Spor Outdoor > Spor/Fitness > Fitness - Kondisyon > Koşu Bantları","product_status":"InStock"}; 
    var utagObject = utagData; 
    var utag_data = {"merchant_names":["Finspor"],"new_site":"new","order_store":"Finspor","order_currency":"TRY","page_domain":"www.hepsiburada.com","page_language":"tr-TR","page_site_name":"Hepsiburada","page_site_region":"tr","site_type":"desktop","page_type":"pdp","page_name":"Product Detail","category_path":"/product/spor-outdoor/spor-fitness/fitness-kondisyon/kosu-bantlari/sporkonksbfox008/","page_title":"Fox Fitness New Target 70E 2.5 Hp Motorlu, Masajlı Koşu Fiyatı","page_url":"http://www.hepsiburada.com/fox-fitness-new-target-70e-2-5-hp-motorlu-masajli-kosu-bandi-hediye-secenekleriyle-p-SPORKONKSBFOX0081?magaza=Finspor","page_referring_url":"http://www.hepsiburada.com/gunun-firsati-teklifi?element=1","page_query_string":["magaza=Finspor"],"is_canonical":"1","canonical_url":"http://www.hepsiburada.com/fox-fitness-new-target-70e-2-5-hp-motorlu-masajli-kosu-bandi-hediye-secenekleriyle-pm-sporkonksbfox008","product_prices":["999.00"],"product_unit_prices":["999.00"],"product_brands":["Fox Fitness"],"product_brand":"Fox Fitness","product_skus":["SPORKONKSBFOX0081"],"product_ids":["sporkonksbfox008"],"product_top_5":["sporkonksbfox008"],"product_names":["Fox Fitness New Target 70E 2.5 Hp Motorlu, Masajlı Koşu Bandı (Hediye Seçenekleriyle)"],"product_category_ids":["19249"],"product_categories":["kosu-bantlari"],"shipping_type":["super-hizli"],"product_quantities":["1"],"product_barcodes":["8691128100776"],"product_barcode":"8691128100776","product_name_array":"Fox Fitness New Target 70E 2.5 Hp Motorlu, Masajlı Koşu Bandı (Hediye Seçenekleriyle)","merchant_ids":["95df0e3483104fc1a16cca6e38bc45cc"],"order_subtotal":["999.00"],"category_id_hierarchy":"60001546 > 2147483635 > 353045 > 19249","category_name_hierarchy":"Spor Outdoor > Spor/Fitness > Fitness - Kondisyon > Koşu Bantları","product_status":"InStock"}; 
+0

あなたはセレンのコードを表示していません(ここから回答を得る必要があります) – eLRuLL

答えて

3

ここでjavascriptを実行する必要はありません。あなたは右ページをクリックし、「表示ページのソース」(または類似)をクリックした場合、あなたはJSON形式で右がデータを見つけることができます。過去には

# assuming we're crawling: 
# 'http://www.hepsiburada.com/fox-fitness-new-target-70e-2-5-hp-motorlu-masajli-kosu-bandi-hediye-secenekleriyle-p-SPORKONKSBFOX0081?magaza=Finspor' 

import json 

def parse(self, response): 
    # get the java-script in the <script> node 
    node = response.xpath("//script[contains(text(),'var utagData = ')]/text()") 
    # extract the json bit from the script text with regex 
    data = node.re('= (\{.+\})')[0] 
    # convert json to python dictionary 
    data = json.loads(data) 
    print(data) 
    print(data['merchant_names']) 
    # gives ['Finspor'] 
0

を私はウェブサイトをクロールし、私は必要なコンテンツを取得するには、このライブラリを使用:

//get title 
xray('http://google.com', 'title')(function(err, title) { 
    console.log(title); 
}) 

またはファインダーで見つける:

xray('http://reddit.com', '.content')(function(err, innerHTML) { 
    console.log(innerHTML); 
}) 

それはあなたが必要とする具体的なデータを見つけるために良いAPIを持っています10

なって具体的な属性値:

xray('http://techcrunch.com', '[email protected]')(function(err, value) { 
    console.log(value); 
}) 

だから、このライブラリに目を通してください。たぶんそれはあなたが必要な結果を達成するのに役立ちます。

関連する問題