python 爬取贝壳网小区名称_利用python爬取贝壳网租房信息

#@Author: Rainbowhhy#@Date : 19-6-25 下午6:35

importrequestsimporttimefrom lxml importetreeimportxlsxwriterdefget_html(page):"""获取网站html代码"""url= "https://bj.zu.ke.com/zufang/pg{}/#contentList".format(page)

headers={'user-agent': 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36'}

response= requests.get(url, headers=headers).textreturnresponsedefparse_html(htmlcode, data):"""解析html代码"""content=etree.HTML(htmlcode)

results= content.xpath('///div[@class="content__article"]/div[1]/div')for result inresults[:]:

community= result.xpath('./div[1]/p[@class="content__list--item--title twoline"]/a/text()')[0].replace('\n','').strip().split()[

0]

address= "-".join(result.xpath('./div/p[@class="content__list--item--des"]/a/text()'))

landlord= result.xpath('./div/p[@class="content__list--item--brand oneline"]/text()')[0].replace('\n','').strip() iflen(

result.xpath('./div/p[@class="content__list--item--brand oneline"]/text()')) > 0 else ""postime= result.xpath('./div/p[@class="content__list--item--time oneline"]/text()')[0]

introduction= ",".join(result.xpath('./div/p[@class="content__list--item--bottom oneline"]/i/text()'))

price= result.xpath('./div/span/em/text()')[0]

description= "".join(result.xpath('./div/p[2]/text()')).replace('\n', '').replace('-', '').strip().split()

area=description[0]

count=len(description)if count == 6:

orientation= description[1] + description[2] + description[3] + description[4]elif count == 5:

orientation= description[1] + description[2] + description[3]elif count == 4:

orientation= description[1] + description[2]elif count == 3:

orientation= description[1]else:

orientation= ""pattern= description[-1]

floor= "".join(result.xpath('./div/p[2]/span/text()')[1].replace('\n', '').strip().split()).strip() iflen(

result.xpath('./div/p[2]/span/text()')) > 1 else ""date_time= time.strftime("%Y-%m-%d", time.localtime())"""数据存入字典"""data_dict={"community": community,"address": address,"landlord": landlord,"postime": postime,"introduction": introduction,"price": '¥' +price,"area": area,"orientation": orientation,"pattern": pattern,"floor": floor,"date_time": date_time

}

data.append(data_dict)defexcel_storage(response):"""将字典数据写入excel"""workbook= xlsxwriter.Workbook('./beikeHouse.xlsx')

worksheet=workbook.add_worksheet()"""设置标题加粗"""bold_format= workbook.add_format({'bold': True})

worksheet.write('A1', '小区名称', bold_format)

worksheet.write('B1', '租房地址', bold_format)

worksheet.write('C1', '房屋来源', bold_format)

worksheet.write('D1', '发布时间', bold_format)

worksheet.write('E1', '租房说明', bold_format)

worksheet.write('F1', '房屋价格', bold_format)

worksheet.write('G1', '房屋面积', bold_format)

worksheet.write('H1', '房屋朝向', bold_format)

worksheet.write('I1', '房屋户型', bold_format)

worksheet.write('J1', '房屋楼层', bold_format)

worksheet.write('K1', '查看日期', bold_format)

row= 1col=0for item inresponse:

worksheet.write_string(row, col, item['community'])

worksheet.write_string(row, col+ 1, item['address'])

worksheet.write_string(row, col+ 2, item['landlord'])

worksheet.write_string(row, col+ 3, item['postime'])

worksheet.write_string(row, col+ 4, item['introduction'])

worksheet.write_string(row, col+ 5, item['price'])

worksheet.write_string(row, col+ 6, item['area'])

worksheet.write_string(row, col+ 7, item['orientation'])

worksheet.write_string(row, col+ 8, item['pattern'])

worksheet.write_string(row, col+ 9, item['floor'])

worksheet.write_string(row, col+ 10, item['date_time'])

row+= 1workbook.close()defmain():

all_datas=[]"""网站总共100页,循环100次"""

for page in range(1, 100):

html=get_html(page)

parse_html(html, all_datas)

excel_storage(all_datas)if __name__ == '__main__':

main()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值