当前位置: 首页 > news >正文

南博会官方网站建设投入广告传媒公司简介

南博会官方网站建设投入,广告传媒公司简介,北京做机床的公司网站,电脑版和手机版网站怎么做前言 前些天发现了一个巨牛的人工智能学习网站#xff0c;通俗易懂#xff0c;风趣幽默#xff0c;忍不住分享一下给大家#xff1a;https://www.captainbed.cn/z ChatGPT体验地址 文章目录 前言引言#xff1a;一、爬虫原理1. HTTP请求与响应过程2. 常用爬虫技术 二、P…前言 前些天发现了一个巨牛的人工智能学习网站通俗易懂风趣幽默忍不住分享一下给大家https://www.captainbed.cn/z ChatGPT体验地址 文章目录 前言引言一、爬虫原理1. HTTP请求与响应过程2. 常用爬虫技术 二、Python爬虫常用库1. 请求库2. 解析库3. 存储库 三、编写一个简单的Python爬虫四、爬虫实战案例1. 分析网站结构2. 编写爬虫代码 五、爬虫注意事项与技巧结语 引言 随着互联网的快速发展数据成为了新时代的石油。Python作为一种高效、易学的编程语言在数据采集领域有着广泛的应用。本文将详细讲解Python爬虫的原理、常用库以及实战案例帮助读者掌握爬虫技能。 一、爬虫原理 爬虫又称网络爬虫是一种自动获取网页内容的程序。它模拟人类浏览网页的行为发送HTTP请求获取网页源代码再通过解析、提取等技术手段获取所需数据。 1. HTTP请求与响应过程 爬虫首先向目标网站发送HTTP请求请求可以包含多种参数如URL、请求方法GET或POST、请求头Headers等。服务器接收到请求后返回相应的HTTP响应包括状态码、响应头和响应体网页内容。 2. 常用爬虫技术 1请求库如requests、aiohttp等用于发送HTTP请求。 2解析库如BeautifulSoup、lxml、PyQuery等用于解析网页内容。 3存储库如pandas、SQLite等用于存储爬取到的数据。 4异步库如asyncio、aiohttp等用于实现异步爬虫提高爬取效率。 二、Python爬虫常用库 1. 请求库 1requests简洁、强大的HTTP库支持HTTP连接保持和连接池支持SSL证书验证、Cookies等。 2aiohttp基于asyncio的异步HTTP网络库适用于需要高并发的爬虫场景。 2. 解析库 1BeautifulSoup一个HTML和XML的解析库简单易用支持多种解析器。 2lxml一个高效的XML和HTML解析库支持XPath和CSS选择器。 3PyQuery一个Python版的jQuery语法与jQuery类似易于上手。 3. 存储库 1pandas一个强大的数据分析库提供数据结构和数据分析工具支持多种文件格式。 2SQLite一个轻量级的数据库支持SQL查询适用于小型爬虫项目。 三、编写一个简单的Python爬虫 以爬取豆瓣电影TOP250为例讲解如何编写一个简单的Python爬虫。 设计爬虫需求 爬取豆瓣电影TOP250的电影名称、评分、导演等信息。编写代码 1使用requests库发送HTTP请求获取网页源代码。 2使用BeautifulSoup库解析网页内容提取所需数据。 3使用pandas库存储数据并保存为CSV文件。运行爬虫并展示结果 import requests from bs4 import BeautifulSoup import pandas as pd # 豆瓣电影TOP250的基础URL base_url https://movie.douban.com/top250 # 定义一个函数来获取页面内容 def get_page_content(url):headers {User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3}response requests.get(url, headersheaders)if response.status_code 200:return response.textelse:print(请求页面失败:, response.status_code)return None # 定义一个函数来解析页面内容 def parse_page_content(html):soup BeautifulSoup(html, html.parser)movie_list soup.find_all(div, class_item)movies []for movie in movie_list:title movie.find(span, class_title).get_text()rating movie.find(span, class_rating_num).get_text()director movie.find(p, class_).find(a).get_text()movies.append({title: title, rating: rating, director: director})return movies # 定义一个函数来保存数据到CSV文件 def save_to_csv(movies):df pd.DataFrame(movies)df.to_csv(douban_top250.csv, indexFalse, encodingutf_8_sig) # 主函数用于运行爬虫 def main():movies []for i in range(0, 250, 25): # 豆瓣电影TOP250分为10页每页25部电影url f{base_url}?start{i}filterhtml get_page_content(url)if html:movies.extend(parse_page_content(html))save_to_csv(movies)print(爬取完成数据已保存到douban_top250.csv) # 运行主函数 if __name__ __main__:main()在实际使用中需要根据豆瓣网站的实际情况调整以下内容 URL和参数根据豆瓣电影的URL结构和参数进行设置。BeautifulSoup选择器根据网页源代码的结构编写正确的选择器来提取数据。 此外为了遵守网站的使用协议和法律法规请确保在编写爬虫时遵循以下几点 遵守Robots协议不爬取网站禁止爬取的内容。设置合理的请求间隔避免对网站服务器造成过大压力。如果遇到网站的反爬措施如验证码、IP封禁等请合理应对遵守网站规定。使用爬虫获取的数据请勿用于商业目的或侵犯他人隐私。 最后由于网站结构可能会发生变化上述代码可能需要根据实际情况进行调整。在实际应用中请确保您的爬虫行为合法合规。 四、爬虫实战案例 以爬取某招聘网站职位信息为例讲解如何编写一个实用的Python爬虫。 1. 分析网站结构 通过观察招聘网站的URL、参数和页面结构找到职位信息的来源。 2. 编写爬虫代码 1使用requests库发送带参数的HTTP请求获取职位列表。 2使用lxml库解析职位列表提取职位详情页URL。 3使用PyQuery库解析职位详情页提取职位信息。 4使用SQLite数据库存储职位信息。 3. 结果展示与分析 import requests from lxml import etree from pyquery import PyQuery as pq import sqlite3 # 创建或连接SQLite数据库 conn sqlite3.connect(job.db) cursor conn.cursor() # 创建职位信息表 cursor.execute(CREATE TABLE IF NOT EXISTS job (id INTEGER PRIMARY KEY, title TEXT, salary TEXT, company TEXT, location TEXT)) # 分析网站结构后得到的职位列表URL url https://www.example.com/jobs # 发送HTTP请求获取职位列表 params {page: 1, # 假设页面参数为page这里请求第1页city: beijing # 假设城市参数为city这里请求北京地区的职位 } response requests.get(url, paramsparams) response.encoding utf-8 # 设置字符编码防止乱码 # 使用lxml解析职位列表提取职位详情页URL html etree.HTML(response.text) job_list html.xpath(//div[classjob-list]/ul/li/a/href) # 假设职位详情页URL在a标签的href属性中 # 遍历职位详情页URL爬取职位信息 for job_url in job_list:job_response requests.get(job_url)job_response.encoding utf-8job_html pq(job_response.text)# 使用PyQuery解析职位详情页提取职位信息title job_html(.job-title).text() # 假设职位名称在class为job-title的元素中salary job_html(.job-salary).text() # 假设薪资信息在class为job-salary的元素中company job_html(.job-company).text() # 假设公司名称在class为job-company的元素中location job_html(.job-location).text() # 假设工作地点在class为job-location的元素中# 存储职位信息到SQLite数据库cursor.execute(INSERT INTO job (title, salary, company, location) VALUES (?, ?, ?, ?), (title, salary, company, location))conn.commit() # 关闭数据库连接 cursor.close() conn.close()在实际使用中需要根据目标网站的实际情况调整以下内容 URL和参数根据目标网站的URL结构和参数进行设置。Xpath表达式根据网页源代码的结构编写正确的Xpath表达式来提取数据。PyQuery选择器根据网页源代码的结构编写正确的CSS选择器来提取数据。数据库操作根据需要创建合适的数据库表结构并插入数据。 此外为了遵守网站的使用协议和法律法规请确保在编写爬虫时遵循以下几点 遵守Robots协议不爬取网站禁止爬取的内容。设置合理的请求间隔避免对网站服务器造成过大压力。如果遇到网站的反爬措施如验证码、IP封禁等请合理应对遵守网站规定。使用爬虫获取的数据请勿用于商业目的或侵犯他人隐私。 五、爬虫注意事项与技巧 遵循Robots协议 尊重网站的爬虫协议避免爬取禁止爬取的内容。设置合理的请求间隔 避免对目标网站服务器造成过大压力合理设置请求间隔。处理反爬虫策略 了解并应对网站的反爬虫策略如IP封禁、验证码等。使用代理IP、Cookies等技巧 提高爬虫的稳定性和成功率。分布式爬虫的搭建与优化 使用Scrapy-Redis等框架实现分布式爬虫提高爬取效率。 六、Python爬虫框架Scrapy强大的Python爬虫框架支持分布式爬取、多种数据格式、强大的插件系统等。Scrapy-Redis基于Scrapy和Redis的分布式爬虫框架实现分布式爬取和去重功能。 结语 通过本文的讲解相信读者已经对Python爬虫有了较为全面的认识。爬虫技能在数据分析、自然语言处理等领域具有广泛的应用希望读者能够动手实践不断提高自己的技能水平。同时请注意合法合规地进行爬虫遵守相关法律法规。祝您学习愉快
http://www.pierceye.com/news/978445/

相关文章:

  • 最好网站建设公司运营团队南山医院网站建设
  • 微小店网站建设官网杭州网站设计上市公司
  • 合肥装饰公司做的好的网站采购销售管理软件
  • wordpress做后端wordpress的seo优化
  • 学术会议网站怎么做教学工作总结
  • 可以在线做试卷的网站互联网营销与管理
  • 国际重大新闻湛江做网站优化
  • 做app的模板下载网站有哪些长春网上建设网站
  • 建网站多少钱 万户项目管理软件手机版
  • 福州做网站需要多少钱win10 安装wordpress
  • 网站建设大约需要多少钱软文推广平台排名
  • 开发公司 网站建设价格seo优化排名怎么做
  • 网站开发如何使用微信登录鞍山专业做网站公司
  • 电子商务网站建设设计报告关于网站建设的指标
  • 电子商务网站建设实训展示网络技术就业方向
  • 乐清装修网站哪个好wordpress文章商品模板
  • 可以做超链接或锚文本的网站有哪些张店网站制作哪家好
  • 企业商城网站建设价格怎么自己建立公司网站
  • 网站上的广告怎么做工业设计是什么
  • 制作网站用c#做前台设计师合作网站
  • 做网站具体流程wordpress octopress
  • 怎么样增加网站权重图片wordpress博客
  • 网站开发接口文档模板个人在线网站推广
  • 百度关键词排名销售长沙网站优化
  • 阿里云部署多个网站wordpress 导航站点
  • 网站品牌词优化怎么做全国网站建设公司
  • 沧州做网站哪家好wordpress站点进入时弹窗
  • 中国化工建设网站做淘宝网站如何提取中间的提成
  • 柳州网站制作推荐怀化网站seo
  • iis网站ip兰州网站排名分析