import requests
import xlwt
import json
def lisw(year_shu):
url = 'https://www.endata.com.cn/API/GetData.ashx'
jian=[]
for h in range(year_shu):
j = 2020 - h
k = {
'year': j,
'MethodName': 'BoxOffice_GetYearInfoData'}
header = {
'Host': 'www.endata.com.cn',
'Origin': 'https://www.endata.com.cn',
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64)'
'AppleWebKit/537.36 (KHTML, like Gecko)'
' Chrome/85.0.4183.83' 'Safari/537.36'}
response = requests.post(url=url, headers=header, data=k)
print(response.text)
c = json.loads(response.text)
lst1 = c['Data']
lst = lst1['Table']
jian.append(lst)
return jian
def main():
columns = ['影片名称', '影片类型', '总票房(万)', '平均票价', '场均人次', '国家及地区', '上映日期','电影宣传图片','电影资料网址']
workbook = xlwt.Workbook(encoding="utf-8")
worksheet = workbook.add_sheet('My Worksheet')
for k in range(len(columns)):
worksheet.write(0, k, columns[k])
workbook.save('movie.xls')
i = 1
for dic in lisw(year_shu):
for item in dic:
for j in range(8):
if j == 0:
worksheet.write(i, j, item["MovieName"])
workbook.save('movie.xls')
if j == 1:
worksheet.write(i, j, item["Genre_Main"])
workbook.save('movie.xls')
if j == 2:
worksheet.write(i, j, item["BoxOffice"])
workbook.save('movie.xls')
if j == 3:
worksheet.write(i, j, item["AvgPrice"])
workbook.save('movie.xls')
if j == 4:
worksheet.write(i, j, item["AvgPeoPle"])
workbook.save('movie.xls')
if j == 5:
worksheet.write(i, j, item["Area"])
workbook.save('movie.xls')
if j == 6:
worksheet.write(i, j, item["ReleaseTime"])
workbook.save('movie.xls')
if j==7 :
worksheet.write(i, j, item["defaultImage"])
worksheet.write(i, j+1, 'https://www.endata.com.cn/BoxOffice/MovieStock/movieShow.html?id='+str(item["BoxOffice"]))
workbook.save('movie.xls')
i = i + 1
if __name__ == '__main__':
year_shu = int(input("请输入几年内:"))
main()
获取中国票房网的N年间年度票房的数据信息(改良完整版代码)
猜你喜欢
转载自blog.csdn.net/liaoqingjian/article/details/108502293
今日推荐
周排行