Scrapy - Bağlantı Çıkarıcılar
Açıklama
Adından da anlaşılacağı gibi, Bağlantı Ayıklayıcılar, web sayfalarından bağlantıları çıkarmak için kullanılan nesnelerdir. scrapy.http.Responsenesneler. Scrapy'de, aşağıdaki gibi yerleşik aspiratörler varscrapy.linkextractors ithalat LinkExtractor. Basit bir arayüz uygulayarak kendi bağlantı çıkarıcınızı ihtiyaçlarınıza göre özelleştirebilirsiniz.
Her bağlantı çıkarıcısının adı verilen genel bir yöntemi vardır extract_linksBu bir Response nesnesi içerir ve scrapy.link.Link nesnelerinin bir listesini döndürür. Bağlantı çıkarıcıları yalnızca bir kez somutlaştırabilir ve farklı yanıtlara sahip bağlantıları çıkarmak için çeşitli zamanlarda extract_links yöntemini çağırabilirsiniz. CrawlSpiderclass, temel amacı bağlantıları çıkarmak olan bir dizi kuralla birlikte bağlantı çıkarıcıları kullanır.
Yerleşik Bağlantı Çıkarıcı Referansı
Normalde bağlantı çıkarıcılar Scrapy ile gruplandırılır ve scrapy.linkextractors modülünde sağlanır. Varsayılan olarak, bağlantı çıkarıcı LxmlLinkExtractor ile işlevsellik açısından eşit olan LinkExtractor olacaktır -
from scrapy.linkextractors import LinkExtractor
LxmlLinkExtractor
class scrapy.linkextractors.lxmlhtml.LxmlLinkExtractor(allow = (), deny = (),
allow_domains = (), deny_domains = (), deny_extensions = None, restrict_xpaths = (),
restrict_css = (), tags = ('a', 'area'), attrs = ('href', ),
canonicalize = True, unique = True, process_value = None)
LxmlLinkExtractor kullanışlı filtreleme seçenekleri vardır ve LXML sağlam HTMLParser ile kullanıldığından, bir tavsiye bağlantı çıkarıcı olduğunu.
Sr.No | Parametre ve Açıklama |
---|---|
1 | allow (bir normal ifade (veya listesi)) Ayıklanacak url ile eşleşmesi gereken tek bir ifadeye veya ifade grubuna izin verir. Belirtilmezse, tüm bağlantılarla eşleşecektir. |
2 | deny (bir normal ifade (veya listesi)) Çıkarılmaması gereken url ile eşleşmesi gereken tek bir ifadeyi veya ifade grubunu engeller veya hariç tutar. Bahsedilmez veya boş bırakılırsa istenmeyen bağlantıları ortadan kaldırmayacaktır. |
3 | allow_domains (str veya liste) Bağlantıların çıkarılacağı alan adlarıyla eşleşmesi gereken tek bir dizeye veya dizge listesine izin verir. |
4 | deny_domains (str veya liste) Bağlantıların çıkarılmayacağı alanlarla eşleşmesi gereken tek bir dizeyi veya dizge listesini engeller veya hariç tutar. |
5 | deny_extensions (liste) Bağlantıları çıkarırken uzantılara sahip dizelerin listesini engeller. Ayarlanmamışsa, varsayılan olarak , scrapy.linkextractors paketinde önceden tanımlanmış liste içeren IGNORED_EXTENSIONS olarak ayarlanacaktır . |
6 | restrict_xpaths (str veya liste) Bağlantıların yanıttan çıkarılacağı bir XPath listesi bölgesidir. Verilirse, bağlantılar yalnızca XPath tarafından seçilen metinden çıkarılacaktır. |
7 | restrict_css (str veya liste) Yanıt içindeki CSS seçilmiş bölgelerinden bağlantıları çıkaracak restrict_xpaths parametresine benzer şekilde davranır. |
8 | tags (str veya liste) Bağlantılar çıkarılırken dikkate alınması gereken tek bir etiket veya bir etiket listesi. Varsayılan olarak, ('a', 'alan') olacaktır. |
9 | attrs (liste) Bağlantılar çıkarılırken tek bir öznitelik veya öznitelik listesi dikkate alınmalıdır. Varsayılan olarak ('href',) olacaktır. |
10 | canonicalize (boole) Çıkarılan url, scrapy.utils.url.canonicalize_url kullanılarak standart forma getirilir . Varsayılan olarak, True olacaktır. |
11 | unique (boole) Çıkarılan bağlantılar tekrarlanırsa kullanılacaktır. |
12 | process_value (çağrılabilir) Taranan etiketlerden ve özniteliklerden bir değer alan bir işlevdir. Alınan değer değiştirilebilir ve iade edilebilir, aksi takdirde bağlantıyı reddetmek için hiçbir şey iade edilmeyecektir. Kullanılmazsa, varsayılan olarak lambda x: x olacaktır. |
Misal
Aşağıdaki kod, bağlantıları çıkarmak için kullanılır -
<a href = "javascript:goToPage('../other/page.html'); return false">Link text</a>
Aşağıdaki kod işlevi process_value'da kullanılabilir -
def process_value(val):
m = re.search("javascript:goToPage\('(.*?)'", val)
if m:
return m.group(1)