webscout 8.2.9__py3-none-any.whl → 2026.1.19__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- webscout/AIauto.py +524 -251
- webscout/AIbase.py +247 -319
- webscout/AIutel.py +68 -703
- webscout/Bard.py +1072 -1026
- webscout/Extra/GitToolkit/__init__.py +10 -10
- webscout/Extra/GitToolkit/gitapi/__init__.py +20 -12
- webscout/Extra/GitToolkit/gitapi/gist.py +142 -0
- webscout/Extra/GitToolkit/gitapi/organization.py +91 -0
- webscout/Extra/GitToolkit/gitapi/repository.py +308 -195
- webscout/Extra/GitToolkit/gitapi/search.py +162 -0
- webscout/Extra/GitToolkit/gitapi/trending.py +236 -0
- webscout/Extra/GitToolkit/gitapi/user.py +128 -96
- webscout/Extra/GitToolkit/gitapi/utils.py +82 -62
- webscout/Extra/YTToolkit/README.md +443 -375
- webscout/Extra/YTToolkit/YTdownloader.py +953 -957
- webscout/Extra/YTToolkit/__init__.py +3 -3
- webscout/Extra/YTToolkit/transcriber.py +595 -476
- webscout/Extra/YTToolkit/ytapi/README.md +230 -44
- webscout/Extra/YTToolkit/ytapi/__init__.py +22 -6
- webscout/Extra/YTToolkit/ytapi/captions.py +190 -0
- webscout/Extra/YTToolkit/ytapi/channel.py +302 -307
- webscout/Extra/YTToolkit/ytapi/errors.py +13 -13
- webscout/Extra/YTToolkit/ytapi/extras.py +178 -118
- webscout/Extra/YTToolkit/ytapi/hashtag.py +120 -0
- webscout/Extra/YTToolkit/ytapi/https.py +89 -88
- webscout/Extra/YTToolkit/ytapi/patterns.py +61 -61
- webscout/Extra/YTToolkit/ytapi/playlist.py +59 -59
- webscout/Extra/YTToolkit/ytapi/pool.py +8 -8
- webscout/Extra/YTToolkit/ytapi/query.py +143 -40
- webscout/Extra/YTToolkit/ytapi/shorts.py +122 -0
- webscout/Extra/YTToolkit/ytapi/stream.py +68 -63
- webscout/Extra/YTToolkit/ytapi/suggestions.py +97 -0
- webscout/Extra/YTToolkit/ytapi/utils.py +66 -62
- webscout/Extra/YTToolkit/ytapi/video.py +403 -232
- webscout/Extra/__init__.py +2 -3
- webscout/Extra/gguf.py +1298 -684
- webscout/Extra/tempmail/README.md +487 -487
- webscout/Extra/tempmail/__init__.py +28 -28
- webscout/Extra/tempmail/async_utils.py +143 -141
- webscout/Extra/tempmail/base.py +172 -161
- webscout/Extra/tempmail/cli.py +191 -187
- webscout/Extra/tempmail/emailnator.py +88 -84
- webscout/Extra/tempmail/mail_tm.py +378 -361
- webscout/Extra/tempmail/temp_mail_io.py +304 -292
- webscout/Extra/weather.py +196 -194
- webscout/Extra/weather_ascii.py +17 -15
- webscout/Provider/AISEARCH/PERPLEXED_search.py +175 -0
- webscout/Provider/AISEARCH/Perplexity.py +292 -333
- webscout/Provider/AISEARCH/README.md +106 -279
- webscout/Provider/AISEARCH/__init__.py +16 -9
- webscout/Provider/AISEARCH/brave_search.py +298 -0
- webscout/Provider/AISEARCH/iask_search.py +357 -410
- webscout/Provider/AISEARCH/monica_search.py +200 -220
- webscout/Provider/AISEARCH/webpilotai_search.py +242 -255
- webscout/Provider/Algion.py +413 -0
- webscout/Provider/Andi.py +74 -69
- webscout/Provider/Apriel.py +313 -0
- webscout/Provider/Ayle.py +323 -0
- webscout/Provider/ChatSandbox.py +329 -342
- webscout/Provider/ClaudeOnline.py +365 -0
- webscout/Provider/Cohere.py +232 -208
- webscout/Provider/DeepAI.py +367 -0
- webscout/Provider/Deepinfra.py +467 -340
- webscout/Provider/EssentialAI.py +217 -0
- webscout/Provider/ExaAI.py +274 -261
- webscout/Provider/Gemini.py +175 -169
- webscout/Provider/GithubChat.py +385 -369
- webscout/Provider/Gradient.py +286 -0
- webscout/Provider/Groq.py +556 -801
- webscout/Provider/HadadXYZ.py +323 -0
- webscout/Provider/HeckAI.py +392 -375
- webscout/Provider/HuggingFace.py +387 -0
- webscout/Provider/IBM.py +340 -0
- webscout/Provider/Jadve.py +317 -291
- webscout/Provider/K2Think.py +306 -0
- webscout/Provider/Koboldai.py +221 -384
- webscout/Provider/Netwrck.py +273 -270
- webscout/Provider/Nvidia.py +310 -0
- webscout/Provider/OPENAI/DeepAI.py +489 -0
- webscout/Provider/OPENAI/K2Think.py +423 -0
- webscout/Provider/OPENAI/PI.py +463 -0
- webscout/Provider/OPENAI/README.md +890 -952
- webscout/Provider/OPENAI/TogetherAI.py +405 -0
- webscout/Provider/OPENAI/TwoAI.py +255 -357
- webscout/Provider/OPENAI/__init__.py +148 -40
- webscout/Provider/OPENAI/ai4chat.py +348 -293
- webscout/Provider/OPENAI/akashgpt.py +436 -0
- webscout/Provider/OPENAI/algion.py +303 -0
- webscout/Provider/OPENAI/{exachat.py → ayle.py} +365 -444
- webscout/Provider/OPENAI/base.py +253 -249
- webscout/Provider/OPENAI/cerebras.py +296 -0
- webscout/Provider/OPENAI/chatgpt.py +870 -556
- webscout/Provider/OPENAI/chatsandbox.py +233 -173
- webscout/Provider/OPENAI/deepinfra.py +403 -322
- webscout/Provider/OPENAI/e2b.py +2370 -1414
- webscout/Provider/OPENAI/elmo.py +278 -0
- webscout/Provider/OPENAI/exaai.py +452 -417
- webscout/Provider/OPENAI/freeassist.py +446 -0
- webscout/Provider/OPENAI/gradient.py +448 -0
- webscout/Provider/OPENAI/groq.py +380 -364
- webscout/Provider/OPENAI/hadadxyz.py +292 -0
- webscout/Provider/OPENAI/heckai.py +333 -308
- webscout/Provider/OPENAI/huggingface.py +321 -0
- webscout/Provider/OPENAI/ibm.py +425 -0
- webscout/Provider/OPENAI/llmchat.py +253 -0
- webscout/Provider/OPENAI/llmchatco.py +378 -335
- webscout/Provider/OPENAI/meta.py +541 -0
- webscout/Provider/OPENAI/netwrck.py +374 -357
- webscout/Provider/OPENAI/nvidia.py +317 -0
- webscout/Provider/OPENAI/oivscode.py +348 -287
- webscout/Provider/OPENAI/openrouter.py +328 -0
- webscout/Provider/OPENAI/pydantic_imports.py +1 -172
- webscout/Provider/OPENAI/sambanova.py +397 -0
- webscout/Provider/OPENAI/sonus.py +305 -304
- webscout/Provider/OPENAI/textpollinations.py +370 -339
- webscout/Provider/OPENAI/toolbaz.py +375 -413
- webscout/Provider/OPENAI/typefully.py +419 -355
- webscout/Provider/OPENAI/typliai.py +279 -0
- webscout/Provider/OPENAI/utils.py +314 -318
- webscout/Provider/OPENAI/wisecat.py +359 -387
- webscout/Provider/OPENAI/writecream.py +185 -163
- webscout/Provider/OPENAI/x0gpt.py +462 -365
- webscout/Provider/OPENAI/zenmux.py +380 -0
- webscout/Provider/OpenRouter.py +386 -0
- webscout/Provider/Openai.py +337 -496
- webscout/Provider/PI.py +443 -429
- webscout/Provider/QwenLM.py +346 -254
- webscout/Provider/STT/__init__.py +28 -0
- webscout/Provider/STT/base.py +303 -0
- webscout/Provider/STT/elevenlabs.py +264 -0
- webscout/Provider/Sambanova.py +317 -0
- webscout/Provider/TTI/README.md +69 -82
- webscout/Provider/TTI/__init__.py +37 -7
- webscout/Provider/TTI/base.py +147 -64
- webscout/Provider/TTI/claudeonline.py +393 -0
- webscout/Provider/TTI/magicstudio.py +292 -201
- webscout/Provider/TTI/miragic.py +180 -0
- webscout/Provider/TTI/pollinations.py +331 -221
- webscout/Provider/TTI/together.py +334 -0
- webscout/Provider/TTI/utils.py +14 -11
- webscout/Provider/TTS/README.md +186 -192
- webscout/Provider/TTS/__init__.py +43 -10
- webscout/Provider/TTS/base.py +523 -159
- webscout/Provider/TTS/deepgram.py +286 -156
- webscout/Provider/TTS/elevenlabs.py +189 -111
- webscout/Provider/TTS/freetts.py +218 -0
- webscout/Provider/TTS/murfai.py +288 -113
- webscout/Provider/TTS/openai_fm.py +364 -129
- webscout/Provider/TTS/parler.py +203 -111
- webscout/Provider/TTS/qwen.py +334 -0
- webscout/Provider/TTS/sherpa.py +286 -0
- webscout/Provider/TTS/speechma.py +693 -580
- webscout/Provider/TTS/streamElements.py +275 -333
- webscout/Provider/TTS/utils.py +280 -280
- webscout/Provider/TextPollinationsAI.py +331 -308
- webscout/Provider/TogetherAI.py +450 -0
- webscout/Provider/TwoAI.py +309 -475
- webscout/Provider/TypliAI.py +311 -305
- webscout/Provider/UNFINISHED/ChatHub.py +219 -209
- webscout/Provider/{OPENAI/glider.py → UNFINISHED/ChutesAI.py} +331 -326
- webscout/Provider/{GizAI.py → UNFINISHED/GizAI.py} +300 -295
- webscout/Provider/{Marcus.py → UNFINISHED/Marcus.py} +218 -198
- webscout/Provider/UNFINISHED/Qodo.py +481 -0
- webscout/Provider/{MCPCore.py → UNFINISHED/XenAI.py} +330 -315
- webscout/Provider/UNFINISHED/Youchat.py +347 -330
- webscout/Provider/UNFINISHED/aihumanizer.py +41 -0
- webscout/Provider/UNFINISHED/grammerchecker.py +37 -0
- webscout/Provider/UNFINISHED/liner.py +342 -0
- webscout/Provider/UNFINISHED/liner_api_request.py +246 -263
- webscout/Provider/{samurai.py → UNFINISHED/samurai.py} +231 -224
- webscout/Provider/WiseCat.py +256 -233
- webscout/Provider/WrDoChat.py +390 -370
- webscout/Provider/__init__.py +115 -174
- webscout/Provider/ai4chat.py +181 -174
- webscout/Provider/akashgpt.py +330 -335
- webscout/Provider/cerebras.py +397 -290
- webscout/Provider/cleeai.py +236 -213
- webscout/Provider/elmo.py +291 -283
- webscout/Provider/geminiapi.py +343 -208
- webscout/Provider/julius.py +245 -223
- webscout/Provider/learnfastai.py +333 -325
- webscout/Provider/llama3mitril.py +230 -215
- webscout/Provider/llmchat.py +308 -258
- webscout/Provider/llmchatco.py +321 -306
- webscout/Provider/meta.py +996 -801
- webscout/Provider/oivscode.py +332 -309
- webscout/Provider/searchchat.py +316 -292
- webscout/Provider/sonus.py +264 -258
- webscout/Provider/toolbaz.py +359 -353
- webscout/Provider/turboseek.py +332 -266
- webscout/Provider/typefully.py +262 -202
- webscout/Provider/x0gpt.py +332 -299
- webscout/__init__.py +31 -39
- webscout/__main__.py +5 -5
- webscout/cli.py +585 -524
- webscout/client.py +1497 -70
- webscout/conversation.py +140 -436
- webscout/exceptions.py +383 -362
- webscout/litagent/__init__.py +29 -29
- webscout/litagent/agent.py +492 -455
- webscout/litagent/constants.py +60 -60
- webscout/models.py +505 -181
- webscout/optimizers.py +74 -420
- webscout/prompt_manager.py +376 -288
- webscout/sanitize.py +1514 -0
- webscout/scout/README.md +452 -404
- webscout/scout/__init__.py +8 -8
- webscout/scout/core/__init__.py +7 -7
- webscout/scout/core/crawler.py +330 -210
- webscout/scout/core/scout.py +800 -607
- webscout/scout/core/search_result.py +51 -96
- webscout/scout/core/text_analyzer.py +64 -63
- webscout/scout/core/text_utils.py +412 -277
- webscout/scout/core/web_analyzer.py +54 -52
- webscout/scout/element.py +872 -478
- webscout/scout/parsers/__init__.py +70 -69
- webscout/scout/parsers/html5lib_parser.py +182 -172
- webscout/scout/parsers/html_parser.py +238 -236
- webscout/scout/parsers/lxml_parser.py +203 -178
- webscout/scout/utils.py +38 -37
- webscout/search/__init__.py +47 -0
- webscout/search/base.py +201 -0
- webscout/search/bing_main.py +45 -0
- webscout/search/brave_main.py +92 -0
- webscout/search/duckduckgo_main.py +57 -0
- webscout/search/engines/__init__.py +127 -0
- webscout/search/engines/bing/__init__.py +15 -0
- webscout/search/engines/bing/base.py +35 -0
- webscout/search/engines/bing/images.py +114 -0
- webscout/search/engines/bing/news.py +96 -0
- webscout/search/engines/bing/suggestions.py +36 -0
- webscout/search/engines/bing/text.py +109 -0
- webscout/search/engines/brave/__init__.py +19 -0
- webscout/search/engines/brave/base.py +47 -0
- webscout/search/engines/brave/images.py +213 -0
- webscout/search/engines/brave/news.py +353 -0
- webscout/search/engines/brave/suggestions.py +318 -0
- webscout/search/engines/brave/text.py +167 -0
- webscout/search/engines/brave/videos.py +364 -0
- webscout/search/engines/duckduckgo/__init__.py +25 -0
- webscout/search/engines/duckduckgo/answers.py +80 -0
- webscout/search/engines/duckduckgo/base.py +189 -0
- webscout/search/engines/duckduckgo/images.py +100 -0
- webscout/search/engines/duckduckgo/maps.py +183 -0
- webscout/search/engines/duckduckgo/news.py +70 -0
- webscout/search/engines/duckduckgo/suggestions.py +22 -0
- webscout/search/engines/duckduckgo/text.py +221 -0
- webscout/search/engines/duckduckgo/translate.py +48 -0
- webscout/search/engines/duckduckgo/videos.py +80 -0
- webscout/search/engines/duckduckgo/weather.py +84 -0
- webscout/search/engines/mojeek.py +61 -0
- webscout/search/engines/wikipedia.py +77 -0
- webscout/search/engines/yahoo/__init__.py +41 -0
- webscout/search/engines/yahoo/answers.py +19 -0
- webscout/search/engines/yahoo/base.py +34 -0
- webscout/search/engines/yahoo/images.py +323 -0
- webscout/search/engines/yahoo/maps.py +19 -0
- webscout/search/engines/yahoo/news.py +258 -0
- webscout/search/engines/yahoo/suggestions.py +140 -0
- webscout/search/engines/yahoo/text.py +273 -0
- webscout/search/engines/yahoo/translate.py +19 -0
- webscout/search/engines/yahoo/videos.py +302 -0
- webscout/search/engines/yahoo/weather.py +220 -0
- webscout/search/engines/yandex.py +67 -0
- webscout/search/engines/yep/__init__.py +13 -0
- webscout/search/engines/yep/base.py +34 -0
- webscout/search/engines/yep/images.py +101 -0
- webscout/search/engines/yep/suggestions.py +38 -0
- webscout/search/engines/yep/text.py +99 -0
- webscout/search/http_client.py +172 -0
- webscout/search/results.py +141 -0
- webscout/search/yahoo_main.py +57 -0
- webscout/search/yep_main.py +48 -0
- webscout/server/__init__.py +48 -0
- webscout/server/config.py +78 -0
- webscout/server/exceptions.py +69 -0
- webscout/server/providers.py +286 -0
- webscout/server/request_models.py +131 -0
- webscout/server/request_processing.py +404 -0
- webscout/server/routes.py +642 -0
- webscout/server/server.py +351 -0
- webscout/server/ui_templates.py +1171 -0
- webscout/swiftcli/__init__.py +79 -95
- webscout/swiftcli/core/__init__.py +7 -7
- webscout/swiftcli/core/cli.py +574 -297
- webscout/swiftcli/core/context.py +98 -104
- webscout/swiftcli/core/group.py +268 -241
- webscout/swiftcli/decorators/__init__.py +28 -28
- webscout/swiftcli/decorators/command.py +243 -221
- webscout/swiftcli/decorators/options.py +247 -220
- webscout/swiftcli/decorators/output.py +392 -252
- webscout/swiftcli/exceptions.py +21 -21
- webscout/swiftcli/plugins/__init__.py +9 -9
- webscout/swiftcli/plugins/base.py +134 -135
- webscout/swiftcli/plugins/manager.py +269 -269
- webscout/swiftcli/utils/__init__.py +58 -59
- webscout/swiftcli/utils/formatting.py +251 -252
- webscout/swiftcli/utils/parsing.py +368 -267
- webscout/update_checker.py +280 -136
- webscout/utils.py +28 -14
- webscout/version.py +2 -1
- webscout/version.py.bak +3 -0
- webscout/zeroart/__init__.py +218 -135
- webscout/zeroart/base.py +70 -66
- webscout/zeroart/effects.py +155 -101
- webscout/zeroart/fonts.py +1799 -1239
- webscout-2026.1.19.dist-info/METADATA +638 -0
- webscout-2026.1.19.dist-info/RECORD +312 -0
- {webscout-8.2.9.dist-info → webscout-2026.1.19.dist-info}/WHEEL +1 -1
- {webscout-8.2.9.dist-info → webscout-2026.1.19.dist-info}/entry_points.txt +1 -1
- webscout/DWEBS.py +0 -520
- webscout/Extra/Act.md +0 -309
- webscout/Extra/GitToolkit/gitapi/README.md +0 -110
- webscout/Extra/autocoder/__init__.py +0 -9
- webscout/Extra/autocoder/autocoder.py +0 -1105
- webscout/Extra/autocoder/autocoder_utiles.py +0 -332
- webscout/Extra/gguf.md +0 -430
- webscout/Extra/weather.md +0 -281
- webscout/Litlogger/README.md +0 -10
- webscout/Litlogger/__init__.py +0 -15
- webscout/Litlogger/formats.py +0 -4
- webscout/Litlogger/handlers.py +0 -103
- webscout/Litlogger/levels.py +0 -13
- webscout/Litlogger/logger.py +0 -92
- webscout/Provider/AI21.py +0 -177
- webscout/Provider/AISEARCH/DeepFind.py +0 -254
- webscout/Provider/AISEARCH/felo_search.py +0 -202
- webscout/Provider/AISEARCH/genspark_search.py +0 -324
- webscout/Provider/AISEARCH/hika_search.py +0 -186
- webscout/Provider/AISEARCH/scira_search.py +0 -298
- webscout/Provider/Aitopia.py +0 -316
- webscout/Provider/AllenAI.py +0 -440
- webscout/Provider/Blackboxai.py +0 -791
- webscout/Provider/ChatGPTClone.py +0 -237
- webscout/Provider/ChatGPTGratis.py +0 -194
- webscout/Provider/Cloudflare.py +0 -324
- webscout/Provider/ExaChat.py +0 -358
- webscout/Provider/Flowith.py +0 -217
- webscout/Provider/FreeGemini.py +0 -250
- webscout/Provider/Glider.py +0 -225
- webscout/Provider/HF_space/__init__.py +0 -0
- webscout/Provider/HF_space/qwen_qwen2.py +0 -206
- webscout/Provider/HuggingFaceChat.py +0 -469
- webscout/Provider/Hunyuan.py +0 -283
- webscout/Provider/LambdaChat.py +0 -411
- webscout/Provider/Llama3.py +0 -259
- webscout/Provider/Nemotron.py +0 -218
- webscout/Provider/OLLAMA.py +0 -396
- webscout/Provider/OPENAI/BLACKBOXAI.py +0 -766
- webscout/Provider/OPENAI/Cloudflare.py +0 -378
- webscout/Provider/OPENAI/FreeGemini.py +0 -283
- webscout/Provider/OPENAI/NEMOTRON.py +0 -232
- webscout/Provider/OPENAI/Qwen3.py +0 -283
- webscout/Provider/OPENAI/api.py +0 -969
- webscout/Provider/OPENAI/c4ai.py +0 -373
- webscout/Provider/OPENAI/chatgptclone.py +0 -494
- webscout/Provider/OPENAI/copilot.py +0 -242
- webscout/Provider/OPENAI/flowith.py +0 -162
- webscout/Provider/OPENAI/freeaichat.py +0 -359
- webscout/Provider/OPENAI/mcpcore.py +0 -389
- webscout/Provider/OPENAI/multichat.py +0 -376
- webscout/Provider/OPENAI/opkfc.py +0 -496
- webscout/Provider/OPENAI/scirachat.py +0 -477
- webscout/Provider/OPENAI/standardinput.py +0 -433
- webscout/Provider/OPENAI/typegpt.py +0 -364
- webscout/Provider/OPENAI/uncovrAI.py +0 -463
- webscout/Provider/OPENAI/venice.py +0 -431
- webscout/Provider/OPENAI/yep.py +0 -382
- webscout/Provider/OpenGPT.py +0 -209
- webscout/Provider/Perplexitylabs.py +0 -415
- webscout/Provider/Reka.py +0 -214
- webscout/Provider/StandardInput.py +0 -290
- webscout/Provider/TTI/aiarta.py +0 -365
- webscout/Provider/TTI/artbit.py +0 -0
- webscout/Provider/TTI/fastflux.py +0 -200
- webscout/Provider/TTI/piclumen.py +0 -203
- webscout/Provider/TTI/pixelmuse.py +0 -225
- webscout/Provider/TTS/gesserit.py +0 -128
- webscout/Provider/TTS/sthir.py +0 -94
- webscout/Provider/TeachAnything.py +0 -229
- webscout/Provider/UNFINISHED/puterjs.py +0 -635
- webscout/Provider/UNFINISHED/test_lmarena.py +0 -119
- webscout/Provider/Venice.py +0 -258
- webscout/Provider/VercelAI.py +0 -253
- webscout/Provider/Writecream.py +0 -246
- webscout/Provider/WritingMate.py +0 -269
- webscout/Provider/asksteve.py +0 -220
- webscout/Provider/chatglm.py +0 -215
- webscout/Provider/copilot.py +0 -425
- webscout/Provider/freeaichat.py +0 -285
- webscout/Provider/granite.py +0 -235
- webscout/Provider/hermes.py +0 -266
- webscout/Provider/koala.py +0 -170
- webscout/Provider/lmarena.py +0 -198
- webscout/Provider/multichat.py +0 -364
- webscout/Provider/scira_chat.py +0 -299
- webscout/Provider/scnet.py +0 -243
- webscout/Provider/talkai.py +0 -194
- webscout/Provider/typegpt.py +0 -289
- webscout/Provider/uncovr.py +0 -368
- webscout/Provider/yep.py +0 -389
- webscout/litagent/Readme.md +0 -276
- webscout/litprinter/__init__.py +0 -59
- webscout/swiftcli/Readme.md +0 -323
- webscout/tempid.py +0 -128
- webscout/webscout_search.py +0 -1184
- webscout/webscout_search_async.py +0 -654
- webscout/yep_search.py +0 -347
- webscout/zeroart/README.md +0 -89
- webscout-8.2.9.dist-info/METADATA +0 -1033
- webscout-8.2.9.dist-info/RECORD +0 -289
- {webscout-8.2.9.dist-info → webscout-2026.1.19.dist-info}/licenses/LICENSE.md +0 -0
- {webscout-8.2.9.dist-info → webscout-2026.1.19.dist-info}/top_level.txt +0 -0
webscout/scout/README.md
CHANGED
|
@@ -1,404 +1,452 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
</
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
-
|
|
21
|
-
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
- [
|
|
31
|
-
- [
|
|
32
|
-
- [
|
|
33
|
-
- [
|
|
34
|
-
- [
|
|
35
|
-
- [
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
<
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
#
|
|
89
|
-
crawler = ScoutCrawler(
|
|
90
|
-
|
|
91
|
-
#
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
)
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
print(f"
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
|
131
|
-
|
|
132
|
-
| `
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
- **
|
|
148
|
-
- **
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
#
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
#
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
#
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
#
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
#
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
```
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
1
|
+
**🚀 The Most Advanced HTML Parser & Web Crawler for AI/LLM Data Collection**
|
|
2
|
+
|
|
3
|
+
**🌟 Built for the Future • Powered by Intelligence • Trusted by Developers**
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
## 📋 Overview
|
|
7
|
+
|
|
8
|
+
Scout is an ultra-powerful, enterprise-grade HTML parsing and web crawling library designed for the AI era. Built with LLM data collection in mind, Scout provides unparalleled capabilities for extracting, analyzing, and processing web content at scale. With its BS4-compatible API enhanced with modern features, Scout is the go-to solution for serious web scraping projects.
|
|
9
|
+
|
|
10
|
+
<details open>
|
|
11
|
+
<summary><b>🌟 Why Scout is the Ultimate Choice</b></summary>
|
|
12
|
+
|
|
13
|
+
- **🧠 LLM-Optimized Crawling**: Purpose-built for collecting high-quality training data for Large Language Models
|
|
14
|
+
- **🌐 Subdomain Intelligence**: Automatically discovers and crawls subdomains (e.g., blog.example.com, docs.example.com)
|
|
15
|
+
- **⚡ Lightning-Fast Performance**: Multi-threaded concurrent crawling with intelligent rate limiting
|
|
16
|
+
- **🎯 Surgical Precision**: Advanced content extraction that preserves structure while removing noise
|
|
17
|
+
- **🔍 Deep Analysis**: Built-in NLP capabilities for entity extraction, text analysis, and semantic understanding
|
|
18
|
+
- **🛡️ Enterprise-Ready**: Robust error handling, retry mechanisms, and respect for robots.txt
|
|
19
|
+
- **📊 Rich Data Extraction**: Captures metadata, structured data, semantic content, and more
|
|
20
|
+
- **🔄 Format Flexibility**: Export to JSON, Markdown, CSV, or custom formats
|
|
21
|
+
- **🎨 BS4++ API**: Familiar interface with 10x more features
|
|
22
|
+
|
|
23
|
+
</details>
|
|
24
|
+
|
|
25
|
+
## 📑 Table of Contents
|
|
26
|
+
|
|
27
|
+
- [Installation](#-installation)
|
|
28
|
+
- [Quick Start](#-quick-start)
|
|
29
|
+
- [Features](#-features)
|
|
30
|
+
- [Advanced Usage](#-advanced-usage)
|
|
31
|
+
- [API Reference](#-api-reference)
|
|
32
|
+
- [Dependencies](#-dependencies)
|
|
33
|
+
- [Supported Python Versions](#-supported-python-versions)
|
|
34
|
+
- [Contributing](#-contributing)
|
|
35
|
+
- [License](#-license)
|
|
36
|
+
|
|
37
|
+
## 📦 Installation
|
|
38
|
+
|
|
39
|
+
```bash
|
|
40
|
+
pip install webscout
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
Or install the latest version from GitHub:
|
|
44
|
+
|
|
45
|
+
```bash
|
|
46
|
+
pip install git+https://github.com/pyscout/Webscout.git
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
## 🚀 Quick Start
|
|
50
|
+
|
|
51
|
+
### Basic Parsing
|
|
52
|
+
|
|
53
|
+
```python
|
|
54
|
+
from webscout.scout import Scout
|
|
55
|
+
|
|
56
|
+
# Parse HTML content
|
|
57
|
+
html_content = """
|
|
58
|
+
<html>
|
|
59
|
+
<body>
|
|
60
|
+
<h1>Hello, Scout!</h1>
|
|
61
|
+
<div class="content">
|
|
62
|
+
<p>Web parsing made easy.</p>
|
|
63
|
+
<a href="https://example.com">Link</a>
|
|
64
|
+
</div>
|
|
65
|
+
</body>
|
|
66
|
+
</html>
|
|
67
|
+
"""
|
|
68
|
+
|
|
69
|
+
scout = Scout(html_content)
|
|
70
|
+
|
|
71
|
+
# Find elements
|
|
72
|
+
title = scout.find('h1')
|
|
73
|
+
links = scout.find_all('a')
|
|
74
|
+
|
|
75
|
+
# Extract text
|
|
76
|
+
print(title[0].get_text()) # Output: Hello, Scout!
|
|
77
|
+
print(links.attrs('href')) # Output: ['https://example.com']
|
|
78
|
+
```
|
|
79
|
+
|
|
80
|
+
### Web Crawling
|
|
81
|
+
|
|
82
|
+
```python
|
|
83
|
+
from webscout.scout import ScoutCrawler
|
|
84
|
+
|
|
85
|
+
# Crawl a website with default settings
|
|
86
|
+
crawler = ScoutCrawler('https://example.com') # Default: max_pages=50
|
|
87
|
+
|
|
88
|
+
# Or customize the crawler
|
|
89
|
+
crawler = ScoutCrawler(
|
|
90
|
+
'https://example.com', # base_url
|
|
91
|
+
max_pages=100, # maximum pages to crawl
|
|
92
|
+
tags_to_remove=['script', 'style', 'nav'] # tags to remove from content
|
|
93
|
+
)
|
|
94
|
+
|
|
95
|
+
# Start crawling
|
|
96
|
+
crawled_pages = crawler.crawl()
|
|
97
|
+
|
|
98
|
+
for page in crawled_pages:
|
|
99
|
+
print(f"URL: {page['url']}")
|
|
100
|
+
print(f"Title: {page['title']}")
|
|
101
|
+
print(f"Links found: {len(page['links'])}")
|
|
102
|
+
print(f"Crawl depth: {page['depth']}")
|
|
103
|
+
```
|
|
104
|
+
|
|
105
|
+
### Text Analysis
|
|
106
|
+
|
|
107
|
+
```python
|
|
108
|
+
from webscout.scout import Scout
|
|
109
|
+
|
|
110
|
+
# Parse a webpage
|
|
111
|
+
html = """<div><h1>Climate Change</h1><p>Email us at info@example.com or call 555-123-4567.</p>
|
|
112
|
+
<p>Visit https://climate-action.org for more information.</p></div>"""
|
|
113
|
+
scout = Scout(html)
|
|
114
|
+
|
|
115
|
+
# Analyze text and extract entities
|
|
116
|
+
analysis = scout.analyze_text()
|
|
117
|
+
print(f"Word frequencies: {analysis['word_count']}")
|
|
118
|
+
print(f"Entities found: {analysis['entities']}")
|
|
119
|
+
```
|
|
120
|
+
|
|
121
|
+
## ✨ Features
|
|
122
|
+
|
|
123
|
+
### 🔍 Multiple Parser Support
|
|
124
|
+
|
|
125
|
+
Scout supports multiple HTML/XML parsers, allowing you to choose the best tool for your specific needs:
|
|
126
|
+
|
|
127
|
+
| Parser | Description | Best For |
|
|
128
|
+
|--------|-------------|----------|
|
|
129
|
+
| `html.parser` | Python's built-in parser | General-purpose parsing, no dependencies |
|
|
130
|
+
| `lxml` | Fast C-based parser | Performance-critical applications |
|
|
131
|
+
| `html5lib` | Highly compliant HTML5 parser | Handling malformed HTML |
|
|
132
|
+
| `lxml-xml` | XML parser | XML document parsing |
|
|
133
|
+
|
|
134
|
+
```python
|
|
135
|
+
# Choose your parser
|
|
136
|
+
scout = Scout(html_content, features='lxml') # For speed
|
|
137
|
+
scout = Scout(html_content, features='html5lib') # For compliance
|
|
138
|
+
```
|
|
139
|
+
|
|
140
|
+
### 🌐 Advanced Parsing Capabilities
|
|
141
|
+
|
|
142
|
+
Scout provides powerful tools for navigating and manipulating HTML/XML documents:
|
|
143
|
+
|
|
144
|
+
- **Element Selection**: Find elements by tag name, attributes, CSS selectors, and more
|
|
145
|
+
- **Tree Traversal**: Navigate parent-child relationships and sibling elements
|
|
146
|
+
- **Content Extraction**: Extract text, attributes, and structured data
|
|
147
|
+
- **Document Manipulation**: Modify, replace, or remove elements
|
|
148
|
+
- **Dynamic Building**: Easily append or insert new nodes
|
|
149
|
+
|
|
150
|
+
#### CSS Selector Support
|
|
151
|
+
|
|
152
|
+
Scout includes a comprehensive CSS selector engine that supports all common selector types:
|
|
153
|
+
|
|
154
|
+
```python
|
|
155
|
+
# Tag selectors
|
|
156
|
+
paragraphs = scout.select('p')
|
|
157
|
+
divs = scout.select('div')
|
|
158
|
+
|
|
159
|
+
# Class selectors
|
|
160
|
+
items = scout.select('.item') # Single class
|
|
161
|
+
cards = scout.select('div.card') # Tag + class
|
|
162
|
+
special = scout.select('.card.special') # Multiple classes
|
|
163
|
+
|
|
164
|
+
# ID selectors
|
|
165
|
+
header = scout.select_one('#header') # Single element by ID
|
|
166
|
+
menu = scout.select('nav#main-menu') # Tag + ID
|
|
167
|
+
|
|
168
|
+
# Attribute selectors
|
|
169
|
+
links = scout.select('a[href]') # Has attribute
|
|
170
|
+
external = scout.select('a[rel="nofollow"]') # Attribute value
|
|
171
|
+
images = scout.select('img[alt]') # Has alt attribute
|
|
172
|
+
|
|
173
|
+
# Descendant selectors (space)
|
|
174
|
+
nested = scout.select('div p') # Any p inside div
|
|
175
|
+
deep = scout.select('article section p') # Deeply nested
|
|
176
|
+
|
|
177
|
+
# Child selectors (>)
|
|
178
|
+
direct = scout.select('ul > li') # Direct children only
|
|
179
|
+
menu_items = scout.select('nav#menu > ul > li') # Multiple levels
|
|
180
|
+
|
|
181
|
+
# Combined selectors
|
|
182
|
+
complex = scout.select('div.container > p.text[lang="en"]')
|
|
183
|
+
links = scout.select('ol#results > li.item a[href]')
|
|
184
|
+
|
|
185
|
+
# Get first match only
|
|
186
|
+
first = scout.select_one('p.intro')
|
|
187
|
+
```
|
|
188
|
+
|
|
189
|
+
**Supported Selector Types:**
|
|
190
|
+
- **Tag**: `p`, `div`, `a`
|
|
191
|
+
- **Class**: `.class`, `div.class`, `.class1.class2`
|
|
192
|
+
- **ID**: `#id`, `div#id`
|
|
193
|
+
- **Attribute**: `[attr]`, `[attr="value"]`
|
|
194
|
+
- **Descendant**: `div p`, `article section p`
|
|
195
|
+
- **Child**: `div > p`, `ul > li`
|
|
196
|
+
- **Combined**: `p.class#id[attr="value"]`
|
|
197
|
+
|
|
198
|
+
#### Element Navigation
|
|
199
|
+
|
|
200
|
+
```python
|
|
201
|
+
# Advanced find with attribute matching
|
|
202
|
+
results = scout.find_all('a', attrs={'class': 'external', 'rel': 'nofollow'})
|
|
203
|
+
|
|
204
|
+
# Tree traversal
|
|
205
|
+
parent = element.find_parent('div')
|
|
206
|
+
siblings = element.find_next_siblings('p')
|
|
207
|
+
prev_sibling = element.find_previous_sibling('p')
|
|
208
|
+
```
|
|
209
|
+
|
|
210
|
+
### 🧠 Intelligent Analysis
|
|
211
|
+
|
|
212
|
+
Scout includes built-in analysis tools for extracting insights from web content:
|
|
213
|
+
|
|
214
|
+
#### Text Analysis
|
|
215
|
+
|
|
216
|
+
```python
|
|
217
|
+
# Extract and analyze text
|
|
218
|
+
text = scout.get_text()
|
|
219
|
+
word_counts = scout.text_analyzer.count_words(text)
|
|
220
|
+
entities = scout.text_analyzer.extract_entities(text)
|
|
221
|
+
```
|
|
222
|
+
|
|
223
|
+
#### Web Structure Analysis
|
|
224
|
+
|
|
225
|
+
```python
|
|
226
|
+
# Analyze page structure
|
|
227
|
+
structure = scout.analyze_page_structure()
|
|
228
|
+
print(f"Most common tags: {structure['tag_distribution']}")
|
|
229
|
+
print(f"Page depth: {max(structure['depth_analysis'].keys())}")
|
|
230
|
+
```
|
|
231
|
+
|
|
232
|
+
#### Semantic Information Extraction
|
|
233
|
+
|
|
234
|
+
```python
|
|
235
|
+
# Extract semantic information
|
|
236
|
+
semantics = scout.extract_semantic_info()
|
|
237
|
+
print(f"Headings: {semantics['headings']}")
|
|
238
|
+
print(f"Lists: {len(semantics['lists']['ul']) + len(semantics['lists']['ol'])}")
|
|
239
|
+
print(f"Tables: {semantics['tables']['count']}")
|
|
240
|
+
```
|
|
241
|
+
|
|
242
|
+
### 🕸️ Web Crawling
|
|
243
|
+
|
|
244
|
+
Scout includes a powerful concurrent web crawler for fetching and analyzing multiple pages:
|
|
245
|
+
|
|
246
|
+
```python
|
|
247
|
+
from webscout.scout import ScoutCrawler
|
|
248
|
+
|
|
249
|
+
# Create a crawler with default settings
|
|
250
|
+
crawler = ScoutCrawler('https://example.com') # Default: max_pages=50
|
|
251
|
+
|
|
252
|
+
# Or customize the crawler with specific options
|
|
253
|
+
crawler = ScoutCrawler(
|
|
254
|
+
'https://example.com', # base_url
|
|
255
|
+
max_pages=100, # maximum pages to crawl
|
|
256
|
+
tags_to_remove=['script', 'style', 'nav'] # tags to remove from content
|
|
257
|
+
)
|
|
258
|
+
|
|
259
|
+
# Start crawling
|
|
260
|
+
pages = crawler.crawl()
|
|
261
|
+
|
|
262
|
+
# Process results
|
|
263
|
+
for page in pages:
|
|
264
|
+
print(f"URL: {page['url']}")
|
|
265
|
+
print(f"Title: {page['title']}")
|
|
266
|
+
print(f"Links: {len(page['links'])}")
|
|
267
|
+
print(f"Depth: {page['depth']}")
|
|
268
|
+
```
|
|
269
|
+
|
|
270
|
+
The crawler automatically:
|
|
271
|
+
- Stays within the same domain as the base URL
|
|
272
|
+
- Uses concurrent requests for faster crawling
|
|
273
|
+
- Removes unwanted tags (like scripts and styles) for cleaner text extraction
|
|
274
|
+
- Tracks crawl depth for each page
|
|
275
|
+
|
|
276
|
+
### 📄 Format Conversion
|
|
277
|
+
|
|
278
|
+
Scout can convert HTML to various formats:
|
|
279
|
+
|
|
280
|
+
```python
|
|
281
|
+
# Convert to JSON
|
|
282
|
+
json_data = scout.to_json(indent=2)
|
|
283
|
+
|
|
284
|
+
# Convert to Markdown
|
|
285
|
+
markdown = scout.to_markdown(heading_style='ATX')
|
|
286
|
+
|
|
287
|
+
# Pretty-print HTML
|
|
288
|
+
pretty_html = scout.prettify()
|
|
289
|
+
```
|
|
290
|
+
|
|
291
|
+
## 🔬 Advanced Usage
|
|
292
|
+
|
|
293
|
+
### Working with Search Results
|
|
294
|
+
|
|
295
|
+
Scout's search methods return a `ScoutSearchResult` object with powerful methods for processing results:
|
|
296
|
+
|
|
297
|
+
```python
|
|
298
|
+
from webscout.scout import Scout
|
|
299
|
+
|
|
300
|
+
scout = Scout(html_content)
|
|
301
|
+
|
|
302
|
+
# Find all paragraphs
|
|
303
|
+
paragraphs = scout.find_all('p')
|
|
304
|
+
|
|
305
|
+
# Extract all text from results
|
|
306
|
+
all_text = paragraphs.texts(separator='\n')
|
|
307
|
+
|
|
308
|
+
# Extract specific attributes
|
|
309
|
+
hrefs = paragraphs.attrs('href')
|
|
310
|
+
|
|
311
|
+
# Filter results with a predicate function
|
|
312
|
+
important = paragraphs.filter(lambda p: 'important' in p.get('class', []))
|
|
313
|
+
|
|
314
|
+
# Transform results
|
|
315
|
+
word_counts = paragraphs.map(lambda p: len(p.get_text().split()))
|
|
316
|
+
|
|
317
|
+
# Analyze text in results
|
|
318
|
+
analysis = paragraphs.analyze_text()
|
|
319
|
+
```
|
|
320
|
+
|
|
321
|
+
### URL Handling and Analysis
|
|
322
|
+
|
|
323
|
+
```python
|
|
324
|
+
from webscout.scout import Scout
|
|
325
|
+
|
|
326
|
+
scout = Scout(html_content)
|
|
327
|
+
|
|
328
|
+
# Parse and analyze URLs
|
|
329
|
+
links = scout.extract_links(base_url='https://example.com')
|
|
330
|
+
for link in links:
|
|
331
|
+
url_components = scout.url_parse(link['href'])
|
|
332
|
+
print(f"Domain: {url_components['netloc']}")
|
|
333
|
+
print(f"Path: {url_components['path']}")
|
|
334
|
+
```
|
|
335
|
+
|
|
336
|
+
### Metadata Extraction
|
|
337
|
+
|
|
338
|
+
```python
|
|
339
|
+
from webscout.scout import Scout
|
|
340
|
+
|
|
341
|
+
scout = Scout(html_content)
|
|
342
|
+
|
|
343
|
+
# Extract metadata
|
|
344
|
+
metadata = scout.extract_metadata()
|
|
345
|
+
print(f"Title: {metadata['title']}")
|
|
346
|
+
print(f"Description: {metadata['description']}")
|
|
347
|
+
print(f"Open Graph: {metadata['og_metadata']}")
|
|
348
|
+
print(f"Twitter Card: {metadata['twitter_metadata']}")
|
|
349
|
+
```
|
|
350
|
+
|
|
351
|
+
### Content Hashing and Caching
|
|
352
|
+
|
|
353
|
+
```python
|
|
354
|
+
from webscout.scout import Scout
|
|
355
|
+
|
|
356
|
+
scout = Scout(html_content)
|
|
357
|
+
|
|
358
|
+
# Generate content hash
|
|
359
|
+
content_hash = scout.hash_content(method='sha256')
|
|
360
|
+
|
|
361
|
+
# Use caching for expensive operations
|
|
362
|
+
if not scout.cache('parsed_data'):
|
|
363
|
+
data = scout.extract_semantic_info()
|
|
364
|
+
scout.cache('parsed_data', data)
|
|
365
|
+
|
|
366
|
+
cached_data = scout.cache('parsed_data')
|
|
367
|
+
```
|
|
368
|
+
|
|
369
|
+
## 📚 API Reference
|
|
370
|
+
|
|
371
|
+
### Core Classes
|
|
372
|
+
|
|
373
|
+
| Class | Description |
|
|
374
|
+
|-------|-------------|
|
|
375
|
+
| `Scout` | Main class for HTML parsing and traversal |
|
|
376
|
+
| `ScoutCrawler` | Web crawler for fetching and parsing multiple pages |
|
|
377
|
+
| `ScoutTextAnalyzer` | Text analysis utilities |
|
|
378
|
+
| `ScoutWebAnalyzer` | Web page analysis utilities |
|
|
379
|
+
| `ScoutSearchResult` | Enhanced search results with filtering and analysis |
|
|
380
|
+
| `Tag` | Represents an HTML/XML tag |
|
|
381
|
+
| `NavigableString` | Represents text within an HTML/XML document |
|
|
382
|
+
|
|
383
|
+
### Key Methods
|
|
384
|
+
|
|
385
|
+
#### Scout Class
|
|
386
|
+
|
|
387
|
+
- `__init__(markup, features='html.parser', from_encoding=None)`: Initialize with HTML content
|
|
388
|
+
- `find(name, attrs={}, recursive=True, text=None)`: Find first matching element
|
|
389
|
+
- `find_all(name, attrs={}, recursive=True, text=None, limit=None)`: Find all matching elements
|
|
390
|
+
- `find_next(name, attrs={}, text=None)`: Find next element in document order
|
|
391
|
+
- `find_all_next(name, attrs={}, text=None, limit=None)`: Find all next elements in document order
|
|
392
|
+
- `find_previous(name, attrs={}, text=None)`: Find previous element in document order
|
|
393
|
+
- `find_all_previous(name, attrs={}, text=None, limit=None)`: Find all previous elements in document order
|
|
394
|
+
- `select(selector)`: Find elements using CSS selector
|
|
395
|
+
- `get_text(separator=' ', strip=False)`: Extract text from document
|
|
396
|
+
- `analyze_text()`: Perform text analysis
|
|
397
|
+
- `analyze_page_structure()`: Analyze document structure
|
|
398
|
+
- `extract_semantic_info()`: Extract semantic information
|
|
399
|
+
- `extract_links(base_url=None)`: Extract all links
|
|
400
|
+
- `extract_metadata()`: Extract metadata from document
|
|
401
|
+
- `to_json(indent=2)`: Convert to JSON
|
|
402
|
+
- `to_markdown(heading_style='ATX')`: Convert to Markdown
|
|
403
|
+
- `prettify(formatter='minimal')`: Pretty-print HTML
|
|
404
|
+
|
|
405
|
+
#### ScoutCrawler Class
|
|
406
|
+
|
|
407
|
+
- `__init__(base_url, max_pages=50, tags_to_remove=None)`: Initialize the crawler
|
|
408
|
+
- `crawl()`: Start crawling from the base URL
|
|
409
|
+
- `_crawl_page(url, depth=0)`: Crawl a single page (internal method)
|
|
410
|
+
- `_is_valid_url(url)`: Check if a URL is valid (internal method)
|
|
411
|
+
|
|
412
|
+
For detailed API documentation, please refer to the [documentation](https://github.com/pyscout/Webscout/wiki).
|
|
413
|
+
|
|
414
|
+
## 🔧 Dependencies
|
|
415
|
+
|
|
416
|
+
- `curl_cffi`: HTTP library used for web requests
|
|
417
|
+
- `lxml`: XML and HTML processing library (optional, recommended)
|
|
418
|
+
- `html5lib`: Standards-compliant HTML parser (optional)
|
|
419
|
+
- `markdownify`: HTML to Markdown conversion
|
|
420
|
+
- `concurrent.futures`: Asynchronous execution (standard library)
|
|
421
|
+
|
|
422
|
+
## 🌈 Supported Python Versions
|
|
423
|
+
|
|
424
|
+
- Python 3.8+
|
|
425
|
+
|
|
426
|
+
## 🤝 Contributing
|
|
427
|
+
|
|
428
|
+
Contributions are welcome! Here's how you can contribute:
|
|
429
|
+
|
|
430
|
+
1. Fork the repository
|
|
431
|
+
2. Create a feature branch (`git checkout -b feature/amazing-feature`)
|
|
432
|
+
3. Commit your changes (`git commit -m 'Add some amazing feature'`)
|
|
433
|
+
4. Push to the branch (`git push origin feature/amazing-feature`)
|
|
434
|
+
5. Open a Pull Request
|
|
435
|
+
|
|
436
|
+
Please make sure to update tests as appropriate.
|
|
437
|
+
|
|
438
|
+
## 📄 License
|
|
439
|
+
|
|
440
|
+
This project is licensed under the MIT License - see the LICENSE file for details.
|
|
441
|
+
|
|
442
|
+
---
|
|
443
|
+
|
|
444
|
+
<div align="center">
|
|
445
|
+
<p>Made with ❤️ by the Webscout team</p>
|
|
446
|
+
<p>
|
|
447
|
+
<a href="https://github.com/pyscout/Webscout">GitHub</a> •
|
|
448
|
+
<a href="https://github.com/pyscout/Webscout/wiki">Documentation</a> •
|
|
449
|
+
<a href="https://github.com/pyscout/Webscout/issues">Report Bug</a> •
|
|
450
|
+
<a href="https://github.com/pyscout/Webscout/issues">Request Feature</a>
|
|
451
|
+
</p>
|
|
452
|
+
</div>
|