[leboncoin] fix select values
This commit is contained in:
parent
f89f3a83ee
commit
8816be46f5
3 changed files with 80 additions and 9 deletions
|
|
@ -18,7 +18,7 @@
|
||||||
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
|
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
from weboob.browser2 import PagesBrowser, URL
|
from weboob.browser2 import PagesBrowser, URL
|
||||||
|
from weboob.capabilities.housing import Query
|
||||||
from .pages import CityListPage, HousingListPage, HousingPage
|
from .pages import CityListPage, HousingListPage, HousingPage
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -26,10 +26,16 @@ class LeboncoinBrowser(PagesBrowser):
|
||||||
BASEURL = 'http://www.leboncoin.fr'
|
BASEURL = 'http://www.leboncoin.fr'
|
||||||
city = URL('ajax/location_list.html\?city=(?P<city>.*)&zipcode=(?P<zip>.*)', CityListPage)
|
city = URL('ajax/location_list.html\?city=(?P<city>.*)&zipcode=(?P<zip>.*)', CityListPage)
|
||||||
search = URL('(?P<type>.*)/offres/ile_de_france/occasions/\?ps=(?P<ps>.*)&pe=(?P<pe>.*)&ros=(?P<ros>.*)&location=(?P<location>.*)&sqs=(?P<sqs>.*)&sqe=(?P<sqe>.*)&ret=(?P<ret>.*)&f=(?P<advert_type>.*)',
|
search = URL('(?P<type>.*)/offres/ile_de_france/occasions/\?ps=(?P<ps>.*)&pe=(?P<pe>.*)&ros=(?P<ros>.*)&location=(?P<location>.*)&sqs=(?P<sqs>.*)&sqe=(?P<sqe>.*)&ret=(?P<ret>.*)&f=(?P<advert_type>.*)',
|
||||||
'(ventes_immobilieres|locations)/offres/ile_de_france/occasions/\?.*',
|
'(?P<_type>.*)/offres/ile_de_france/occasions.*?',
|
||||||
HousingListPage)
|
HousingListPage)
|
||||||
housing = URL('ventes_immobilieres/(?P<_id>.*).htm', HousingPage)
|
housing = URL('ventes_immobilieres/(?P<_id>.*).htm', HousingPage)
|
||||||
|
|
||||||
|
RET = {Query.HOUSE_TYPES.HOUSE: '1',
|
||||||
|
Query.HOUSE_TYPES.APART: '2',
|
||||||
|
Query.HOUSE_TYPES.LAND: '3',
|
||||||
|
Query.HOUSE_TYPES.PARKING: '4',
|
||||||
|
Query.HOUSE_TYPES.OTHER: '5'}
|
||||||
|
|
||||||
def get_cities(self, pattern):
|
def get_cities(self, pattern):
|
||||||
city = ''
|
city = ''
|
||||||
zip_code = ''
|
zip_code = ''
|
||||||
|
|
@ -40,7 +46,8 @@ class LeboncoinBrowser(PagesBrowser):
|
||||||
|
|
||||||
return self.city.go(city=city, zip=zip_code).get_cities()
|
return self.city.go(city=city, zip=zip_code).get_cities()
|
||||||
|
|
||||||
def search_housings(self, type, cities, nb_rooms, area_min, area_max, cost_min, cost_max, ret, advert_type):
|
def search_housings(self, query, advert_type):
|
||||||
|
type, cities, nb_rooms, area_min, area_max, cost_min, cost_max, ret = self.decode_query(query)
|
||||||
return self.search.go(location=cities,
|
return self.search.go(location=cities,
|
||||||
ros=nb_rooms,
|
ros=nb_rooms,
|
||||||
sqs=area_min,
|
sqs=area_min,
|
||||||
|
|
@ -53,3 +60,33 @@ class LeboncoinBrowser(PagesBrowser):
|
||||||
|
|
||||||
def get_housing(self, _id, obj=None):
|
def get_housing(self, _id, obj=None):
|
||||||
return self.housing.go(_id=_id).get_housing(obj=obj)
|
return self.housing.go(_id=_id).get_housing(obj=obj)
|
||||||
|
|
||||||
|
def decode_query(self, query):
|
||||||
|
cities = []
|
||||||
|
for c in query.cities:
|
||||||
|
cities.append('%s %s' % (c.id, c.name))
|
||||||
|
|
||||||
|
if len(cities) == 0:
|
||||||
|
return list()
|
||||||
|
|
||||||
|
ret = []
|
||||||
|
for g in query.house_types:
|
||||||
|
if g in self.RET:
|
||||||
|
ret.append(self.RET.get(g))
|
||||||
|
|
||||||
|
if len(ret) == 0:
|
||||||
|
return list()
|
||||||
|
|
||||||
|
_type = 'ventes_immobilieres'
|
||||||
|
if query.type == Query.TYPE_RENT:
|
||||||
|
_type = 'locations'
|
||||||
|
|
||||||
|
self.search.go(_type=_type)
|
||||||
|
|
||||||
|
nb_rooms = '' if not query.nb_rooms else self.page.get_rooms_min(query.nb_rooms)
|
||||||
|
area_min = '' if not query.area_min else self.page.get_area_min(query.area_min)
|
||||||
|
area_max = '' if not query.area_max else self.page.get_area_max(query.area_max)
|
||||||
|
cost_min = '' if not query.cost_min else self.page.get_cost_min(query.cost_min)
|
||||||
|
cost_max = '' if not query.cost_max else self.page.get_cost_max(query.cost_max)
|
||||||
|
|
||||||
|
return _type, ','.join(cities), nb_rooms, area_min, area_max, cost_min, cost_max, '&ret='.join(ret)
|
||||||
|
|
|
||||||
|
|
@ -19,7 +19,7 @@
|
||||||
|
|
||||||
|
|
||||||
from weboob.tools.backend import Module, BackendConfig
|
from weboob.tools.backend import Module, BackendConfig
|
||||||
from weboob.capabilities.housing import CapHousing, Query, Housing, HousingPhoto
|
from weboob.capabilities.housing import CapHousing, Housing, HousingPhoto
|
||||||
from weboob.tools.value import Value
|
from weboob.tools.value import Value
|
||||||
from .browser import LeboncoinBrowser
|
from .browser import LeboncoinBrowser
|
||||||
|
|
||||||
|
|
@ -39,13 +39,13 @@ class LeboncoinModule(Module, CapHousing):
|
||||||
|
|
||||||
CONFIG = BackendConfig(Value('advert_type', label='Advert type',
|
CONFIG = BackendConfig(Value('advert_type', label='Advert type',
|
||||||
choices={'c': 'Agency', 'p': 'Owner', 'a': 'All'}, default='a'))
|
choices={'c': 'Agency', 'p': 'Owner', 'a': 'All'}, default='a'))
|
||||||
|
"""
|
||||||
RET = {Query.HOUSE_TYPES.HOUSE: '1',
|
RET = {Query.HOUSE_TYPES.HOUSE: '1',
|
||||||
Query.HOUSE_TYPES.APART: '2',
|
Query.HOUSE_TYPES.APART: '2',
|
||||||
Query.HOUSE_TYPES.LAND: '3',
|
Query.HOUSE_TYPES.LAND: '3',
|
||||||
Query.HOUSE_TYPES.PARKING: '4',
|
Query.HOUSE_TYPES.PARKING: '4',
|
||||||
Query.HOUSE_TYPES.OTHER: '5'}
|
Query.HOUSE_TYPES.OTHER: '5'}
|
||||||
|
"""
|
||||||
def get_housing(self, _id):
|
def get_housing(self, _id):
|
||||||
return self.browser.get_housing(_id)
|
return self.browser.get_housing(_id)
|
||||||
|
|
||||||
|
|
@ -61,6 +61,7 @@ class LeboncoinModule(Module, CapHousing):
|
||||||
return self.browser.get_cities(pattern)
|
return self.browser.get_cities(pattern)
|
||||||
|
|
||||||
def search_housings(self, query):
|
def search_housings(self, query):
|
||||||
|
"""
|
||||||
cities = []
|
cities = []
|
||||||
for c in query.cities:
|
for c in query.cities:
|
||||||
cities.append('%s %s' % (c.id, c.name))
|
cities.append('%s %s' % (c.id, c.name))
|
||||||
|
|
@ -90,5 +91,7 @@ class LeboncoinModule(Module, CapHousing):
|
||||||
area_min, area_max,
|
area_min, area_max,
|
||||||
cost_min, cost_max, '&ret='.join(ret),
|
cost_min, cost_max, '&ret='.join(ret),
|
||||||
self.config['advert_type'].get())
|
self.config['advert_type'].get())
|
||||||
|
"""
|
||||||
|
return self.browser.search_housings(query, self.config['advert_type'].get())
|
||||||
|
|
||||||
OBJECTS = {Housing: fill_housing, HousingPhoto: fill_photo}
|
OBJECTS = {Housing: fill_housing, HousingPhoto: fill_photo}
|
||||||
|
|
|
||||||
|
|
@ -16,7 +16,6 @@
|
||||||
#
|
#
|
||||||
# You should have received a copy of the GNU Affero General Public License
|
# You should have received a copy of the GNU Affero General Public License
|
||||||
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
|
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
from decimal import Decimal
|
from decimal import Decimal
|
||||||
from weboob.browser2.page import HTMLPage, method, pagination
|
from weboob.browser2.page import HTMLPage, method, pagination
|
||||||
from weboob.browser2.elements import ItemElement, ListElement
|
from weboob.browser2.elements import ItemElement, ListElement
|
||||||
|
|
@ -40,6 +39,38 @@ class CityListPage(HTMLPage):
|
||||||
|
|
||||||
|
|
||||||
class HousingListPage(HTMLPage):
|
class HousingListPage(HTMLPage):
|
||||||
|
def get_area_min(self, asked_area):
|
||||||
|
return self.find_select_value(asked_area, '//select[@id="sqs"]/option')
|
||||||
|
|
||||||
|
def get_area_max(self, asked_area):
|
||||||
|
return self.find_select_value(asked_area, '//select[@id="sqe"]/option')
|
||||||
|
|
||||||
|
def get_rooms_min(self, asked_rooms):
|
||||||
|
return self.find_select_value(asked_rooms, '//select[@id="ros"]/option')
|
||||||
|
|
||||||
|
# def get_rooms_max(self, asked_rooms):
|
||||||
|
# return self.find_select_value(asked_rooms, '//select[@id="roe"]/option')
|
||||||
|
|
||||||
|
def get_cost_min(self, asked_cost):
|
||||||
|
return self.find_select_value(asked_cost, '//select[@id="ps"]/option')
|
||||||
|
|
||||||
|
def get_cost_max(self, asked_cost):
|
||||||
|
return self.find_select_value(asked_cost, '//select[@id="pe"]/option')
|
||||||
|
|
||||||
|
def find_select_value(self, ref_value, selector):
|
||||||
|
select = {}
|
||||||
|
for item in self.doc.xpath(selector):
|
||||||
|
if item.attrib['value']:
|
||||||
|
select[CleanDecimal('.')(item)] = CleanDecimal('./@value')(item)
|
||||||
|
|
||||||
|
select_keys = select.keys()
|
||||||
|
select_keys.sort()
|
||||||
|
for select_value in select_keys:
|
||||||
|
if select_value >= ref_value:
|
||||||
|
return select[select_value]
|
||||||
|
|
||||||
|
return select[select_keys[-1]]
|
||||||
|
|
||||||
@pagination
|
@pagination
|
||||||
@method
|
@method
|
||||||
class get_housing_list(ListElement):
|
class get_housing_list(ListElement):
|
||||||
|
|
@ -116,8 +147,8 @@ class HousingPage(HTMLPage):
|
||||||
obj_area = Env('area')
|
obj_area = Env('area')
|
||||||
|
|
||||||
def obj_date(self):
|
def obj_date(self):
|
||||||
_date = Regexp(CleanText('//div[@class="upload_by"]', replace=[(u'à', '')]),
|
_date = Regexp(CleanText('//div[@class="upload_by"]', replace=[(u'à', '')]),
|
||||||
'.*- Mise en ligne le (.*).')(self)
|
'.*- Mise en ligne le (.*).')(self)
|
||||||
|
|
||||||
for fr, en in DATE_TRANSLATE_FR:
|
for fr, en in DATE_TRANSLATE_FR:
|
||||||
_date = fr.sub(en, _date)
|
_date = fr.sub(en, _date)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue