Add new engine: SJP
This commit is contained in:
		
							parent
							
								
									547478089f
								
							
						
					
					
						commit
						6631f11305
					
				
							
								
								
									
										82
									
								
								searx/engines/sjp.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										82
									
								
								searx/engines/sjp.py
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,82 @@
 | 
				
			|||||||
 | 
					# SPDX-License-Identifier: AGPL-3.0-or-later
 | 
				
			||||||
 | 
					"""Słownik Języka Polskiego (general)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					"""
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					from lxml.html import fromstring
 | 
				
			||||||
 | 
					from searx import logger
 | 
				
			||||||
 | 
					from searx.utils import extract_text
 | 
				
			||||||
 | 
					from searx.raise_for_httperror import raise_for_httperror
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					logger = logger.getChild('sjp engine')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# about
 | 
				
			||||||
 | 
					about = {
 | 
				
			||||||
 | 
					    "website": 'https://sjp.pwn.pl',
 | 
				
			||||||
 | 
					    "wikidata_id": 'Q55117369',
 | 
				
			||||||
 | 
					    "official_api_documentation": None,
 | 
				
			||||||
 | 
					    "use_official_api": False,
 | 
				
			||||||
 | 
					    "require_api_key": False,
 | 
				
			||||||
 | 
					    "results": 'HTML',
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					categories = ['general']
 | 
				
			||||||
 | 
					paging = False
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					URL = 'https://sjp.pwn.pl'
 | 
				
			||||||
 | 
					SEARCH_URL = URL + '/szukaj/{query}.html'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					def request(query, params):
 | 
				
			||||||
 | 
					    params['url'] = SEARCH_URL.format(query=query)
 | 
				
			||||||
 | 
					    logger.debug(f"query_url --> {params['url']}")
 | 
				
			||||||
 | 
					    return params
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					def response(resp):
 | 
				
			||||||
 | 
					    results = []
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    raise_for_httperror(resp)
 | 
				
			||||||
 | 
					    dom = fromstring(resp.text)
 | 
				
			||||||
 | 
					    word = extract_text(dom.xpath('//*[@id="content"]/div/div[1]/div/div[1]/div[1]/div[2]/div/div/div[2]/div/div'))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    definitions = []
 | 
				
			||||||
 | 
					    for src in dom.xpath('//*[@id="content"]/div/div[1]/div/div[1]/div[1]/div[2]/div/div/div/div/div/div'):
 | 
				
			||||||
 | 
					        src_text = extract_text(src.xpath('./h1/span[@class="entry-head-title"]/text()')).strip()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        src_defs = []
 | 
				
			||||||
 | 
					        for def_item in src.xpath('./div/div[contains(@class, "ribbon-element")]'):
 | 
				
			||||||
 | 
					            if def_item.xpath('./div[@class="znacz"]'):
 | 
				
			||||||
 | 
					                sub_defs = []
 | 
				
			||||||
 | 
					                for def_sub_item in def_item.xpath('./div[@class="znacz"]'):
 | 
				
			||||||
 | 
					                    def_sub_text = extract_text(def_sub_item).lstrip('0123456789. ')
 | 
				
			||||||
 | 
					                    sub_defs.append(def_sub_text)
 | 
				
			||||||
 | 
					                src_defs.append((word, sub_defs))
 | 
				
			||||||
 | 
					            else:
 | 
				
			||||||
 | 
					                def_text = extract_text(def_item).strip()
 | 
				
			||||||
 | 
					                src_defs.append((def_text, ''))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        definitions.append((src_text, src_defs))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if not definitions:
 | 
				
			||||||
 | 
					        return results
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    infobox = ''
 | 
				
			||||||
 | 
					    for src in definitions:
 | 
				
			||||||
 | 
					        infobox += f"<div><small>{src[0]}</small>"
 | 
				
			||||||
 | 
					        infobox += "<ul>"
 | 
				
			||||||
 | 
					        for (def_text, sub_def) in src[1]:
 | 
				
			||||||
 | 
					            infobox += f"<li>{def_text}</li>"
 | 
				
			||||||
 | 
					            if sub_def:
 | 
				
			||||||
 | 
					                infobox += "<ol>"
 | 
				
			||||||
 | 
					                for sub_def_text in sub_def:
 | 
				
			||||||
 | 
					                    infobox += f"<li>{sub_def_text}</li>"
 | 
				
			||||||
 | 
					                infobox += "</ol>"
 | 
				
			||||||
 | 
					        infobox += "</ul></div>"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    results.append({
 | 
				
			||||||
 | 
					        'infobox': word,
 | 
				
			||||||
 | 
					        'content': infobox,
 | 
				
			||||||
 | 
					    })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return results
 | 
				
			||||||
@ -1271,6 +1271,14 @@ engines:
 | 
				
			|||||||
    categories: videos
 | 
					    categories: videos
 | 
				
			||||||
    disabled : True
 | 
					    disabled : True
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  - name: słownik języka polskiego
 | 
				
			||||||
 | 
					    engine: sjp
 | 
				
			||||||
 | 
					    shortcut: sjp
 | 
				
			||||||
 | 
					    base_url: https://sjp.pwn.pl/
 | 
				
			||||||
 | 
					    categories: general
 | 
				
			||||||
 | 
					    timeout: 5.0
 | 
				
			||||||
 | 
					    disabled: True
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Doku engine lets you access to any Doku wiki instance:
 | 
					# Doku engine lets you access to any Doku wiki instance:
 | 
				
			||||||
# A public one or a privete/corporate one.
 | 
					# A public one or a privete/corporate one.
 | 
				
			||||||
#  - name : ubuntuwiki
 | 
					#  - name : ubuntuwiki
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user