发布一个网站需要什么伦敦 wordpress 设计

张小明 2026/3/12 18:57:49
发布一个网站需要什么,伦敦 wordpress 设计,宾阳网站建设,藁城网站建设随着OpenAI大火#xff0c;从事AI开发的人趋之若鹜#xff0c;这次使用Python selenium抓取了领英上几万条岗位薪资数据#xff0c;并使用Pandas、matplotlib、seaborn等库进行可视化探索分析。 但领英设置了一些反爬措施#xff0c;对IP进行限制封禁#xff0c;因此会用到…随着OpenAI大火从事AI开发的人趋之若鹜这次使用Python selenium抓取了领英上几万条岗位薪资数据并使用Pandas、matplotlib、seaborn等库进行可视化探索分析。但领英设置了一些反爬措施对IP进行限制封禁因此会用到IP代理用不同的IP进行访问我这里用的是亮数据的IP代理。亮数据是一家提供网络数据采集解决方案的网站它拥有全球最大的代理IP网络覆盖超过195个国家和地区拥有超过7200万个不重复的真人IP地址。这些IP地址可以用于匿名浏览网页、绕过IP封锁、抓取网页数据等。亮数据官网地址https://get.brightdata.com/weijun另外亮数据提供各种数据采集工具帮助企业轻松采集网页数据。这些工具包括Web Scraper IDE、亮数据浏览器、SERP API等等。下面是关于Python爬取领英的步骤和代码。1、爬虫采集AI岗位数据-selenium亮数据2、处理和清洗数据-pandas3、可视化数据探索-matplotlib seaborn1、爬虫采集AI岗位数据-selenium亮数据# 导入相关库 import random from selenium import webdriver from selenium.webdriver.common.by import By import time import requests import pandas as pd from scripts.helpers import strip_val, get_value_by_path # 选择Edge浏览器 BROWSER edge # 创建网络会话登录Linkedin # create_session函数用于创建一个自动化的浏览器会话并使用提供的电子邮件和密码登录LinkedIn。 # 它首先根据BROWSER变量选择相应的浏览器驱动程序Chrome或Edge然后导航到LinkedIn的登录页面自动填写登录表单并提交。 # 登录成功后它会获取当前会话的cookies并创建一个requests.Session对象来保存这些cookies以便后续的HTTP请求可以保持登录状态。最后它返回这个会话对象。 def create_session(email, password): if BROWSER chrome: driver webdriver.Chrome() elif BROWSER edge: driver webdriver.Edge() # 登录信息 driver.get(https://www.linkedin.com/checkpoint/rm/sign-in-another-account) time.sleep(1) driver.find_element(By.ID, username).send_keys(email) driver.find_element(By.ID, password).send_keys(password) driver.find_element(By.XPATH, //*[idorganic-div]/form/div[3]/button).click() time.sleep(1) input(Press ENTER after a successful login for {}: .format(email)) driver.get(https://www.linkedin.com/jobs/search/?) time.sleep(1) cookies driver.get_cookies() driver.quit() session requests.Session() for cookie in cookies: session.cookies.set(cookie[name], cookie[value]) return session # 获取登录账号和密码 def get_logins(method): logins pd.read_csv(logins.csv) logins logins[logins[method] method] emails logins[emails].tolist() passwords logins[passwords].tolist() return emails, passwords # JobSearchRetriever类用于检索LinkedIn上的职位信息。 # 它初始化时设置了一个职位搜索链接并获取登录凭证来创建多个会话。 # 它还定义了一个get_jobs方法该方法通过会话发送HTTP GET请求到LinkedIn的职位搜索API获取职位信息并解析响应以提取职位ID和标题。 # 如果职位被标记为赞助即广告它也会记录下来。 class JobSearchRetriever: def __init__(self): self.job_search_link https://www.linkedin.com/voyager/api/voyagerJobsDashJobCards?decorationIdcom.linkedin.voyager.dash.deco.jobs.search.JobSearchCardsCollection-187count100qjobSearchquery(origin:JOB_SEARCH_PAGE_OTHER_ENTRY,selectedFilters:(sortBy:List(DD)),spellCorrectionEnabled:true)start0 emails, passwords get_logins(search) self.sessions [create_session(email, password) for email, password in zip(emails, passwords)] self.session_index 0 self.headers [{ Authority: www.linkedin.com, Method: GET, Path: voyager/api/voyagerJobsDashJobCards?decorationIdcom.linkedin.voyager.dash.deco.jobs.search.JobSearchCardsCollection-187count25qjobSearchquery(origin:JOB_SEARCH_PAGE_OTHER_ENTRY,selectedFilters:(sortBy:List(DD)),spellCorrectionEnabled:true)start0, Scheme: https, Accept: application/vnd.linkedin.normalizedjson2.1, Accept-Encoding: gzip, deflate, br, Accept-Language: en-US,en;q0.9, Cookie: ; .join([f{key}{value} for key, value in session.cookies.items()]), Csrf-Token: session.cookies.get(JSESSIONID).strip(), # TE: Trailers, User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/117.0.0.0 Safari/537.36, # X-Li-Track: {clientVersion:1.12.7990,mpVersion:1.12.7990,osName:web,timezoneOffset:-7,timezone:America/Los_Angeles,deviceFormFactor:DESKTOP,mpName:voyager-web,displayDensity:1,displayWidth:1920,displayHeight:1080} X-Li-Track: {clientVersion:1.13.5589,mpVersion:1.13.5589,osName:web,timezoneOffset:-7,timezone:America/Los_Angeles,deviceFormFactor:DESKTOP,mpName:voyager-web,displayDensity:1,displayWidth:360,displayHeight:800} } for session in self.sessions] # self.proxies [{http: fhttp://{proxy}, https: fhttp://{proxy}} for proxy in []] # 添加亮数据代理IP # get_jobs函数用于发送HTTP请求到LinkedIn的职位搜索API获取职位信息 # 它使用当前会话索引来选择一个会话并发送带有相应请求头的GET请求。如果响应状态码是200表示请求成功 # 它将解析JSON响应提取职位ID、标题和赞助状态并将这些信息存储在一个字典中。 def get_jobs(self): results self.sessions[self.session_index].get(self.job_search_link, headersself.headers[self.session_index]) #, proxiesself.proxies[self.session_index], timeout5) self.session_index (self.session_index 1) % len(self.sessions) if results.status_code ! 200: raise Exception(Status code {} for search\nText: {}.format(results.status_code, results.text)) results results.json() job_ids {} for r in results[included]: if r[$type] com.linkedin.voyager.dash.jobs.JobPostingCard and referenceId in r: job_id int(strip_val(r[jobPostingUrn], 1)) job_ids[job_id] {sponsored: False} job_ids[job_id][title] r.get(jobPostingTitle) for x in r[footerItems]: if x.get(type) PROMOTED: job_ids[job_id][sponsored] True break return job_ids2、处理和清洗数据-pandas# 导入相关库 import pandas as pd import matplotlib.pyplot as plt import seaborn as sns from wordcloud import WordCloud # 导入职位数据 job_postings pd.read_csv(./archive/job_postings.csv) job_postings # 根据AI岗位关键词筛选AI相关岗位 keywords [data scientist, machine learning, data science, data analyst, ml engineer, data engineer,ai engineer,ai/ml,ai/nlp,ai reasearcher,ai consultant,artificial intelligence,computer vision,deep learning] # 新增一列标注职位是否包含关键字 def check_keywords(description): for keyword in keywords: if keyword in str(description).lower(): return AI岗位 return 非AI岗位 job_postings[is_programmer] job_postings[description].apply(check_keywords) # 保存AI岗位新表 job_ai job_postings[(job_postings[is_programmer]AI岗位) (job_postings[pay_period]YEARLY) (job_postings[max_salary]10000) ] job_others job_postings[(job_postings[is_programmer]非AI岗位) (job_postings[pay_period]YEARLY) (job_postings[max_salary]10000) (job_postings[max_salary]200000) ] job_ai处理好的数据如下3、可视化数据探索-matplotlib seabornAI岗位中位数年薪18W美金最高50w以上# 设置Seaborn样式和调色板 sns.set_style(whitegrid) palette [skyblue] # palette [#87CEEB] # 使用颜色代码或者其他有效的颜色名称这里使用天蓝色的颜色代码 # 箱线图 plt.figure(figsize(8, 6)) sns.boxplot(ymax_salary, datajob_ai, palettepalette) plt.ylabel(Yearly Salary) plt.title(AI Yearly Salary Boxplot) # 添加分位数标注 quantiles job_ai[max_salary].quantile([0.25, 0.5, 0.75]) for q, label in zip(quantiles, [Q1, Median, Q3]): plt.text(0, q, f{label}: {int(q)}, horizontalalignmentcenter, verticalalignmentbottom, fontdict{size: 10}) # 添加平均值、最大最小值标注 avg_value job_ai[max_salary].mean() max_value job_ai[max_salary].max() min_value job_ai[max_salary].min() plt.text(0.2, avg_value, fAvg: {int(avg_value)}, haleft, vabottom, fontdict{size: 10}) plt.text(0, max_value, fMax: {int(max_value)}, hacenter, vabottom, fontdict{size: 10}) plt.text(0, min_value, fMin: {int(min_value)}, hacenter, vatop, fontdict{size: 10}) # 显示图形 plt.show()AI岗位年薪主要集中在15-30w美金# 1. 直方图 plt.figure(figsize(10, 6)) plt.hist(job_ai[max_salary], bins30, colorskyblue, edgecolorblack) plt.xlabel(Yearly Salary) plt.ylabel(Frequency) plt.title(Yearly Salary Distribution) plt.show()AI大多需要高级岗对软件开发、机器学习、数据科学要求较多# 词云 stopwords set([Manager]) job_titles_text .join(job_ai[title]) wordcloud WordCloud(width800, height400, background_colorwhite,stopwordsstopwords).generate(job_titles_text) # 显示词云 plt.figure(figsize(10, 6)) plt.imshow(wordcloud, interpolationbilinear) plt.title(AI Job Title Word Cloud) plt.axis(off) plt.tight_layout() plt.show()数据发现AI岗位平均年薪竟高达18万美金远超普通开发岗而且AI岗位需求也在爆发性增长。这次使用的是亮数据IP服务质量还是蛮高的大家可以试试。亮数据官网地址https://get.brightdata.com/weijun
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

义乌网站建设联系方式明年做那个网站能致富

两挡AMT纯电动汽车仿真模型,可实现换挡过程模拟/ABS/TCS驱动防滑控制/电池管理等功能 模型可以输入WLTC/CLTC等不同工况,可以实时纯电量管理、换挡过程模拟、ABS防抱死控制、TCS驱动防滑控制、电池管理充放电控制、SOC估计等功能。 各个功能模块高度独立…

张小明 2026/3/5 2:45:46 网站建设

案例网站有哪些个人网站做企业备案吗

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个针对电商场景的Redis客户端工具,支持批量操作商品缓存、用户会话管理和实时订单数据分析。工具需提供可视化界面展示缓存命中率、会话活跃度和订单处理延迟等关…

张小明 2026/3/5 2:45:46 网站建设

惠州网站建设电话连云港做网站的

2025-12-17亲测支持最新版本2025.3支持在线更新支持Windows、MAC、Linux 一 下载安装、更新 1. 官网下载最新版安装。 https://www.jetbrains.com/zh-cn/clion/ 安装后以后先不要运行程序。 2. 如果已安装,则直接更新到最新版本即可。如果更新后激活失效&#xff…

张小明 2026/3/5 2:45:47 网站建设

长寿做网站公司网站建设ihanshi

问题一只青蛙想要跳到第 n 级台阶(n 为非负整数)。它每次只能跳 1 级 或 2 级 台阶,问这只青蛙跳到第 n 级台阶共有多少种不同的跳法?举例首先我们先从简单的开始分析:当n1时;青蛙只有一种跳法:…

张小明 2026/3/5 2:45:48 网站建设

网站建设对接视频镇江网站建设优化排名

EmotiVoice开源模型测评:语音自然度与情感表现力全面领先 在虚拟主播直播时突然“情绪上头”,用带着颤抖的嗓音说出一句充满委屈的台词;或是智能客服在检测到用户多次重复提问后,自动切换成温和安抚的语气——这些曾属于科幻场景的…

张小明 2026/3/5 2:45:51 网站建设

温州给企业做网站网站建设类公司排名

项目:用户注册、登录与个人主页(完整 MVP 交付) 本文档提供了一个完整的、可直接落地的用户认证体系 MVP 套件,包括: 产品需求文档(PRD)两个架构决策记录(ADR)OpenAPI 3.…

张小明 2026/3/5 2:45:51 网站建设