| | import os |
| | import requests |
| | from bs4 import BeautifulSoup |
| | import json |
| | import time |
| | import random |
| |
|
| | |
| | OUTPUT_DIR = "scan-candidates" |
| | LIMIT = 20 |
| |
|
| | |
| | CATEGORIES = { |
| | |
| | "pit11": "PIT-11 przykład wypełnienia skan", |
| | "pit37": "PIT-37 wypełniony formularz dane", |
| | "pit36": "PIT-36 uzupełniony przykład", |
| | "pit36L": "PIT-36L wypełniony skan", |
| | "pit28": "PIT-28 wypełniona deklaracja", |
| | "pit38": "PIT-38 przykład uzupełniony", |
| | "pit39": "PIT-39 przykładowe dane", |
| | "pit5": "PIT-5 wypełniony formularz skan", |
| | "pit8C": "PIT-8C wypełniony dane", |
| | "vat7": "VAT-7 deklaracja wypełniona przykład", |
| | "cit8": "CIT-8 uzupełniony formularz", |
| | "pcc3": "PCC-3 wypełniony przykład", |
| | "invoice": "faktura vat wypełniona dane skan", |
| | "proformaInvoice": "faktura proforma uzupełniona dane", |
| | "receipt": "paragon fiskalny zdjęcie realne", |
| | "utilityBill": "rachunek za prąd uzupełniony dane", |
| | "bankStatement": "wyciąg bankowy realny przykład", |
| | "loanAgreement": "umowa pożyczki wypełniona dane", |
| | "insurancePolicy": "polisa ubezpieczeniowa wypełniona skan", |
| |
|
| | |
| | "notarialDeed": "akt notarialny skan z danymi", |
| | "courtJudgment": "wyrok sądu wypełniony uzupełniony", |
| | "powerOfAttorney": "pełnomocnictwo uzupełnione dane", |
| | "employmentContract": "umowa o pracę wypełniona dane", |
| | "mandateContract": "umowa zlecenie uzupełniona przykładowa", |
| | "taskContract": "umowa o dzieło wypełniona skan", |
| | "b2bContract": "umowa B2B wypełniona dane", |
| | "nonCompeteAgreement": "zakaz konkurencji uzupełniony przykład", |
| | "lawsuit": "pozew cywilny wypełniony skan", |
| |
|
| | |
| | "idCard": "dowód osobisty specimen dane polska", |
| | "passport": "paszport polski specimen dane", |
| | "birthCertificate": "odpis aktu urodzenia wypełniony", |
| | "marriageCertificate": "akt małżeństwa uzupełniony dane", |
| | "deathCertificate": "akt zgonu wypełniony przykład", |
| | "peselConfirmation": "potwierdzenie nadania PESEL wypełnione", |
| | "drivingLicense": "prawo jazdy specimen polska", |
| | "schoolCertificate": "świadectwo szkolne wypełnione dane", |
| | "universityDiploma": "dyplom ukończenia studiów wypełniony", |
| | "professionalCertificate": "certyfikat zawodowy uzupełniony", |
| | "cv": "życiorys CV wypełniony dane", |
| |
|
| | |
| | "sickLeave": "zwolnienie lekarskie L4 wypełnione skan", |
| | "prescription": "recepta lekarska wypisana dane", |
| | "medicalResults": "wyniki badań laboratoryjnych dane pacjenta", |
| | "referral": "skierowanie do lekarza uzupełnione", |
| | "medicalHistory": "karta pacjenta wypełniona skan", |
| | "vaccinationCard": "karta szczepień uzupełniona", |
| | "sanitaryBooklet": "książeczka sanepidowska wypełniona", |
| |
|
| | |
| | "propertyDeed": "akt własności nieruchomości uzupełniony", |
| | "landRegistry": "księga wieczysta odpis przykład", |
| | "rentalAgreement": "umowa najmu mieszkania wypełniona dane", |
| | "registrationCertificate": "dowód rejestracyjny pojazdu uzupełniony", |
| | "vehicleHistory": "raport historii pojazdu dane", |
| | "landMap": "mapa geodezyjna skan", |
| | "technicalInspection": "zaświadczenie o badaniu technicznym wypełnione", |
| |
|
| | |
| | "application": "wniosek urzędowy wypełniony skan", |
| | "certificate": "zaświadczenie o niekaralności uzupełnione", |
| | "authorization": "upoważnienie wypełnione dane", |
| | } |
| |
|
| | HEADERS = { |
| | 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36' |
| | } |
| |
|
| | def download_images(query, folder_name): |
| | print(f"\n🚀 POBIERANIE WYPEŁNIONYCH: {folder_name.upper()}") |
| | search_url = f"https://www.bing.com/images/search?q={query.replace(' ', '+')}&form=HDRSC2" |
| | |
| | try: |
| | response = requests.get(search_url, headers=HEADERS, timeout=15) |
| | soup = BeautifulSoup(response.text, 'html.parser') |
| | |
| | target_path = os.path.join(OUTPUT_DIR, folder_name) |
| | os.makedirs(target_path, exist_ok=True) |
| |
|
| | links = [] |
| | for a in soup.find_all("a", {"class": "iusc"}): |
| | if "m" in a.attrs: |
| | m = json.loads(a["m"]) |
| | links.append(m["murl"]) |
| |
|
| | print(f" 🔍 Linki: {len(links)}") |
| | |
| | downloaded = 0 |
| | for url in links: |
| | if downloaded >= LIMIT: break |
| | try: |
| | if any(ext in url.lower() for ext in [".pdf", ".html", ".php"]): continue |
| | ext = ".jpg" if ".png" not in url.lower() else ".png" |
| | |
| | res = requests.get(url, headers=HEADERS, timeout=7) |
| | if res.status_code == 200 and "text/html" not in res.headers.get('Content-Type', ''): |
| | file_name = f"{folder_name}_{downloaded}{ext}" |
| | with open(os.path.join(target_path, file_name), "wb") as f: |
| | f.write(res.content) |
| | print(f" ✅ [{downloaded+1}/{LIMIT}] {file_name}") |
| | downloaded += 1 |
| | if downloaded % 5 == 0: time.sleep(1) |
| | except: continue |
| |
|
| | except Exception as e: |
| | print(f" 🚨 Błąd: {e}") |
| |
|
| | if __name__ == "__main__": |
| | os.makedirs(OUTPUT_DIR, exist_ok=True) |
| | for i, (folder, query) in enumerate(CATEGORIES.items()): |
| | download_images(query, folder) |
| | wait = random.uniform(3, 6) |
| | print(f"😴 Przerwa {wait:.1f}s... ({i+1}/{len(CATEGORIES)})") |
| | time.sleep(wait) |