2021-07-20 20:21:33 +02:00

102 lines
3.6 KiB
Python
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# -*- coding: utf-8 -*-
# Copyright 2021 Mike Fährmann
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 as
# published by the Free Software Foundation.
"""Extractors for https://architizer.com/"""
from .common import GalleryExtractor, Extractor, Message
from .. import text
class ArchitizerProjectExtractor(GalleryExtractor):
"""Extractor for project pages on architizer.com"""
category = "architizer"
subcategory = "project"
root = "https://architizer.com"
directory_fmt = ("{category}", "{firm}", "{title}")
filename_fmt = "{filename}.{extension}"
archive_fmt = "{gid}_{num}"
pattern = r"(?:https?://)?architizer\.com/projects/([^/?#]+)"
test = ("https://architizer.com/projects/house-lo/", {
"pattern": r"https://architizer-prod\.imgix\.net/media/mediadata"
r"/uploads/.+\.jpg$",
"keyword": {
"count": 27,
"description": str,
"firm": "Atelier Lina Bellovicova",
"gid": "225496",
"location": "Czechia",
"num": int,
"size": "1000 sqft - 3000 sqft",
"slug": "house-lo",
"status": "Built",
"subcategory": "project",
"title": "House LO",
"type": "Residential Private House",
"year": "2020",
},
})
def __init__(self, match):
url = "{}/projects/{}/".format(self.root, match.group(1))
GalleryExtractor.__init__(self, match, url)
def metadata(self, page):
extr = text.extract_from(page)
return {
"title" : extr("data-name='", "'"),
"slug" : extr("data-slug='", "'"),
"gid" : extr("data-gid='", "'").rpartition(".")[2],
"firm" : extr("data-firm-leaders-str='", "'"),
"location" : extr("<h2>", "<").strip(),
"type" : text.unescape(text.remove_html(extr(
'<div class="title">Type</div>', '<br'))),
"status" : text.remove_html(extr(
'<div class="title">STATUS</div>', '</')),
"year" : text.remove_html(extr(
'<div class="title">YEAR</div>', '</')),
"size" : text.remove_html(extr(
'<div class="title">SIZE</div>', '</')),
"description": text.unescape(extr(
'<span class="copy js-copy">', '</span></div>')
.replace("<br />", "\n")),
}
def images(self, page):
return [
(url, None)
for url in text.extract_iter(
page, "property='og:image:secure_url' content='", "?")
]
class ArchitizerFirmExtractor(Extractor):
"""Extractor for all projects of a firm"""
category = "architizer"
subcategory = "firm"
root = "https://architizer.com"
pattern = r"(?:https?://)?architizer\.com/firms/([^/?#]+)"
test = ("https://architizer.com/firms/olson-kundig/", {
"pattern": ArchitizerProjectExtractor.pattern,
"count": ">= 90",
})
def __init__(self, match):
Extractor.__init__(self, match)
self.firm = match.group(1)
def items(self):
url = url = "{}/firms/{}/?requesting_merlin=pages".format(
self.root, self.firm)
page = self.request(url).text
data = {"_extractor": ArchitizerProjectExtractor}
for project in text.extract_iter(page, '<a href="/projects/', '"'):
if not project.startswith("q/"):
url = "{}/projects/{}".format(self.root, project)
yield Message.Queue, url, data