哪里可以接做ppt的网站如何建立自己的网站教程

张小明 2026/1/7 13:00:16
哪里可以接做ppt的网站,如何建立自己的网站教程,深圳龙岗区吉华街道邮编,溧阳网站建设价格Aneiang.Pa 高阶用法#xff1a;动态爬虫 SDK 详解与实战 在之前介绍 Aneiang.Pa 的热门新闻爬虫库时#xff0c;我们提到了它支持微博、知乎、B站等十多个平台的热榜数据抓取。但对于有更灵活需求的开发者来说#xff0c;可能需要抓取特定网站的自定义数据结构。今天…Aneiang.Pa 高阶用法动态爬虫 SDK 详解与实战在之前介绍 Aneiang.Pa 的热门新闻爬虫库时我们提到了它支持微博、知乎、B站等十多个平台的热榜数据抓取。但对于有更灵活需求的开发者来说可能需要抓取特定网站的自定义数据结构。今天我们将深入探讨 Aneiang.Pa 的高阶用法——动态爬虫 SDK。什么是动态爬虫 SDK动态爬虫 SDK 是 Aneiang.Pa 提供的一个独立模块它允许你通过简单的模型定义和特性标注快速实现对任意网站数据结构的抓取。无需为每个网站编写特定的解析逻辑只需定义你想要的数据模型SDK 会自动处理 HTML 解析和数据提取。GitHub地址https://github.com/AneiangSoft/Aneiang.PaGitee地址https://gitee.com/aneiangsoft/Aneiang.Pa快速入门1. 安装 NuGet 包首先在你的项目中安装动态爬虫 SDKdotnetaddpackage Aneiang.Pa.Dynamic2. 配置服务在 Startup.cs 或 Program.cs 中注册动态爬虫服务services.AddDynamicScraper(context.Configuration);3. 定义数据模型这是最核心的一步。假设我们要从某个网站抓取工具卡片数据[HtmlContainer(div,htmlClass:tab-content,index:1)][HtmlItem(a)]publicclassToolCard{[HtmlValue(p/b)]publicstringTitle{get;set;}[HtmlValue(.,href)]publicstringUrl{get;set;}[HtmlValue(img,src)]publicstringIcon{get;set;}[HtmlValue(p,htmlClass:card-desc)]publicstringDescription{get;set;}[HtmlValue(span,htmlClass:download-count)]publicstringDownloadCount{get;set;}}4. 使用爬虫publicclassToolService{privatereadonlyIDynamicScraper_scraper;publicToolService(IDynamicScraperscraper){_scraperscraper;}publicasyncTaskListToolCardGetPopularToolsAsync(){vartoolsawait_scraper.DatasetScraperToolCard(https://www.example-tools.com/popular);returntools;}}特性详解HtmlContainerAttribute - 容器定位这个特性标识数据集的容器元素也就是包含所有数据项的父级元素。// 基本用法通过标签名定位[HtmlContainer(div)]// 通过 class 定位[HtmlContainer(div,htmlClass:item-list)]// 通过 id 定位[HtmlContainer(div,htmlId:main-content)]// 当有多个匹配元素时使用 index 指定第几个[HtmlContainer(div,htmlClass:tab-content,index:1)]HtmlItemAttribute - 数据项定位标识单个数据项对应的 HTML 元素这些元素都位于容器内部。// 简单标签定位[HtmlItem(a)]// 带有 class 的项[HtmlItem(div,htmlClass:card-item)]// 列表中的每一项[HtmlItem(li,htmlClass:list-item)]HtmlValueAttribute - 数据提取定义如何从每个数据项中提取具体的字段值。// 从子元素提取文本[HtmlValue(h3)]publicstringTitle{get;set;}// 从特定路径提取[HtmlValue(div/span)]publicstringSubtitle{get;set;}// 从 HTML 属性中提取值[HtmlValue(a,href)]publicstringLink{get;set;}[HtmlValue(img,src)]publicstringImageUrl{get;set;}// 使用当前元素使用 . 选择器[HtmlValue(.,data-id)]publicstringItemId{get;set;}// 通过 class 定位[HtmlValue(p,htmlClass:price)]publicstringPrice{get;set;}选择器语法详解动态爬虫 SDK 使用类似 XPath 但更简洁的选择器语法选择器含义示例匹配结构p/bp 直接子元素中的 bpb文本/b/pp//bp 的任何后代元素中的 bpdivspanb文本/b/span/div/pdiv/p/spandiv p spandivpspan文本/span/p/div.当前元素本身用于提取当前元素的属性实战案例案例 1电商商品列表抓取[HtmlContainer(ul,htmlClass:product-list)][HtmlItem(li,htmlClass:product-item)]publicclassProduct{[HtmlValue(h2/product-name)]publicstringName{get;set;}[HtmlValue(.,data-product-id)]publicstringProductId{get;set;}[HtmlValue(img,src)]publicstringImageUrl{get;set;}[HtmlValue(span/price)]publicdecimalPrice{get;set;}[HtmlValue(div/rating)]publicdoubleRating{get;set;}[HtmlValue(a,href)]publicstringDetailUrl{get;set;}}案例 2新闻文章列表抓取[HtmlContainer(div,htmlClass:article-list)][HtmlItem(article)]publicclassNewsArticle{[HtmlValue(h1/title)]publicstringTitle{get;set;}[HtmlValue(p/summary)]publicstringSummary{get;set;}[HtmlValue(span/author)]publicstringAuthor{get;set;}[HtmlValue(time,datetime)]publicDateTimePublishTime{get;set;}[HtmlValue(div//img,src)]publicstringThumbnail{get;set;}[HtmlValue(a,href)]publicstringArticleUrl{get;set;}}案例 3复杂嵌套结构处理对于复杂的页面结构可以使用相对路径[HtmlContainer(table,htmlClass:data-table)][HtmlItem(tr)]publicclassTableRow{// 第一列使用索引定位[HtmlValue(td[1])]publicstringFirstColumn{get;set;}// 第二列中的链接[HtmlValue(td[2]/a)]publicstringSecondColumnLinkText{get;set;}[HtmlValue(td[2]/a,href)]publicstringSecondColumnLink{get;set;}// 第三列中的多个元素[HtmlValue(td[3]/span,htmlClass:tag)]publicListstringTags{get;set;}}高级功能1. 自定义解析器如果默认的解析逻辑不能满足需求可以实现自定义的值解析器publicclassCustomDateParser:IHtmlValueParser{publicobjectParse(HtmlNodenode,HtmlValueAttributeattribute){vartextnode.InnerText;// 自定义日期解析逻辑returnDateTime.ParseExact(text,yyyy-MM-dd HH:mm,CultureInfo.InvariantCulture);}}// 在模型中使用publicclassArticle{[HtmlValue(time,ParserTypetypeof(CustomDateParser))]publicDateTimeCustomDate{get;set;}}2. 异步数据加载处理对于需要滚动加载或异步加载数据的页面varscraperscope.ServiceProvider.GetRequiredServiceIDynamicScraper();// 配置浏览器模拟选项varoptionsnewScraperOptions{WaitForJavaScripttrue,// 等待 JavaScript 执行ScrollToBottomtrue,// 滚动到页面底部ScrollDelay1000,// 滚动延迟Timeout30000// 超时时间};vardataawaitscraper.DatasetScraperProduct(https://www.infinite-scroll-site.com/products,options);3. 分页处理publicasyncTaskListProductGetAllProductsAsync(){varallProductsnewListProduct();intpage1;boolhasMoretrue;while(hasMore){varurl$https://www.example.com/products?page{page};varproductsawait_scraper.DatasetScraperProduct(url);if(products.Any()){allProducts.AddRange(products);page;// 避免请求过快awaitTask.Delay(1000);}else{hasMorefalse;}}returnallProducts;}最佳实践1. 错误处理try{vardataawait_scraper.DatasetScraperMyModel(url);// 处理数据}catch(HtmlParseExceptionex){// HTML 解析错误_logger.LogError(ex,HTML 解析失败);}catch(NetworkExceptionex){// 网络请求错误_logger.LogError(ex,网络请求失败);}catch(Exceptionex){// 其他错误_logger.LogError(ex,抓取数据时发生错误);}2. 请求限制与礼貌爬取// 使用内置的延迟机制varoptionsnewScraperOptions{DelayBetweenRequests5000,// 5秒延迟MaxRetries3,// 最大重试次数RetryDelay2000// 重试延迟};// 或者手动控制publicasyncTaskListTScrapeWithDelayT(Liststringurls)whereT:class{varresultsnewListT();foreach(varurlinurls){vardataawait_scraper.DatasetScraperT(url);results.AddRange(data);// 礼貌爬取每次请求后暂停awaitTask.Delay(Random.Shared.Next(3000,8000));}returnresults;}3. 缓存策略publicclassCachedScraperService{privatereadonlyIDynamicScraper_scraper;privatereadonlyIMemoryCache_cache;publicasyncTaskListProductGetProductsAsync(boolforceRefreshfalse){varcacheKeyproducts_data;if(!forceRefresh_cache.TryGetValue(cacheKey,outListProductcachedData)){returncachedData;}vardataawait_scraper.DatasetScraperProduct(https://www.example.com/products);// 缓存5分钟_cache.Set(cacheKey,data,TimeSpan.FromMinutes(5));returndata;}}性能优化建议并行处理对于多个独立页面的抓取可以使用并行处理连接复用确保 HttpClient 正确复用选择性抓取只抓取需要的字段减少内存占用流式处理对于大量数据考虑使用流式处理方式// 并行抓取示例publicasyncTaskListProductScrapeMultiplePagesAsync(Liststringurls){vartasksurls.Select(url_scraper.DatasetScraperProduct(url));varresultsawaitTask.WhenAll(tasks);returnresults.SelectMany(rr).ToList();}总结Aneiang.Pa 的动态爬虫 SDK 提供了一种声明式、类型安全的方式来抓取网页数据。通过简单的模型定义和特性标注你可以快速实现各种复杂网站的抓取逻辑而无需深入了解 HTML 解析的细节。这种方式的优势在于代码简洁模型即文档清晰易懂维护方便网站结构变化时只需调整模型特性类型安全编译时检查减少运行时错误灵活扩展支持自定义解析器和高级选项无论是快速原型开发还是生产环境的数据抓取任务Aneiang.Pa 的动态爬虫都是一个强大而实用的工具。提示请始终遵守目标网站的 robots.txt 规则尊重版权和隐私将抓取间隔控制在合理范围避免对目标网站造成过大压力。数据抓取仅应用于合法合规的目的。
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

西安网站建设网络公司跨境电商展会2023

第一章:AI 模型的 Docker 缓存策略在构建 AI 模型服务镜像时,Docker 的缓存机制能显著提升构建效率。合理的缓存策略可以避免重复下载大型依赖包(如 PyTorch、TensorFlow),从而缩短 CI/CD 流程中的构建时间。分层缓存原…

张小明 2026/1/7 6:30:09 网站建设

设计公司网站建设阿里云网站建设官方自营店

企业级智能问答系统怎么选?Kotaemon告诉你答案 在客服工单堆积如山、内部知识散落在几十个文档库和飞书群聊里的今天,企业对“能真正解决问题”的AI助手期待已久。然而现实是:大多数所谓的智能问答系统,要么答非所问,要…

张小明 2026/1/6 0:17:12 网站建设

返利网站做淘宝郑州外贸网站建设公司

第一章:Open-AutoGLM部署前的环境评估 在部署 Open-AutoGLM 之前,全面的环境评估是确保系统稳定运行的关键环节。合理的资源配置和依赖项检查能够有效避免后续部署过程中出现兼容性问题或性能瓶颈。 硬件资源需求分析 Open-AutoGLM 作为基于大语言模型的…

张小明 2026/1/6 0:15:08 网站建设

手机建设网站的目的做网站写需求

Vue-Pure-Admin环境配置实战:3步搞定企业级多环境部署 【免费下载链接】vue-pure-admin 全面ESMVue3ViteElement-PlusTypeScript编写的一款后台管理系统(兼容移动端) 项目地址: https://gitcode.com/GitHub_Trending/vu/vue-pure-admin …

张小明 2026/1/7 8:33:05 网站建设

推广平台怎么赚钱天津网络优化招聘

容器编排与服务发现:Registrator 与 Docker Swarm 模式的应用 在容器化技术蓬勃发展的今天,高效的容器编排和服务发现是确保系统稳定运行的关键。本文将介绍 Registrator 自动服务注册和 Docker Swarm 模式的无缝集群功能,帮助你更轻松地管理容器化应用。 1. Registrator …

张小明 2026/1/6 0:11:04 网站建设

做网站违法上海网站制作哪家好

基于PLC的加热炉控制的设计,西门子S7-200PLC组态王画面,IO表,电路图,说明书,可仿真搞工业自动化的人都知道,PLC控制加热炉是个经典项目。这次拿西门子S7-200开刀,咱们先看现场硬件配置——炉体温…

张小明 2026/1/6 0:06:52 网站建设