上传文件至 /

This commit is contained in:
2026-03-31 11:22:33 +08:00
parent 490fd747cc
commit a8469608ea
2 changed files with 115 additions and 0 deletions

41
26331,09test5.py Normal file
View File

@@ -0,0 +1,41 @@
import requests
import os
import json
poster_urls = [
{'rank': 1, 'title': '肖申克的救赎', 'url': 'https://img3.doubanio.com/view/photo/s_ratio_poster/public/p480747492.jpg'},
{'rank': 2, 'title': '霸王别姬', 'url': 'https://img1.doubanio.com/view/photo/s_ratio_poster/public/p2911205318.jpg'},
{'rank': 3, 'title': '泰坦尼克号', 'url': 'https://img9.doubanio.com/view/photo/s_ratio_poster/public/p457760035.jpg'},
]
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36'
}
os.makedirs('posters', exist_ok=True)
saved_info = []
for info in poster_urls:
try:
response = requests.get(info['url'], headers=headers, timeout=10)
image_data = response.content
filename = f"posters/{info['rank']}_{info['title']}.jpg"
with open(filename, 'wb') as f:
f.write(image_data)
saved_info.append({
'rank': info['rank'],
'title': info['title'],
'filename': filename,
'size': len(image_data)
})
print(f'已保存: {filename} ({len(image_data)} bytes)')
except Exception as e:
print(f'下载失败 {info["title"]}: {e}')
with open('posters/info.json', 'w', encoding='utf-8') as f:
json.dump(saved_info, f, ensure_ascii=False, indent=2)
print('\n图片信息已保存到 posters/info.json')

74
26331,09test6.py Normal file
View File

@@ -0,0 +1,74 @@
import requests
import re
import csv
import json
import os
import time
def crawl_douban_top10():
"""爬取豆瓣Top10电影信息"""
print('开始爬取豆瓣电影Top10...')
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36',
'Accept': 'text/html,application/xhtml+xml',
}
url = 'https://movie.douban.com/top250'
response = requests.get(url, headers=headers, timeout=10)
html = response.text
title_cn = re.findall(r'<span class="title">([^<&]+)</span>', html)
ratings = re.findall(r'<span class="rating_num"[^>]*>(\d+\.?\d*)</span>', html)
quotes = re.findall(r'<span class="inq">([^<]+)</span>', html)
movies = []
cn_index = 0
for i in range(10):
while cn_index < len(title_cn) and title_cn[cn_index].startswith('/'):
cn_index += 1
movie = {
'rank': i + 1,
'title': title_cn[cn_index] if cn_index < len(title_cn) else '',
'rating': ratings[i] if i < len(ratings) else '',
'quote': quotes[i] if i < len(quotes) else ''
}
movies.append(movie)
cn_index += 1
return movies
def save_to_csv(movies, filename):
"""保存为CSV"""
with open(filename, 'w', encoding='utf-8', newline='') as f:
writer = csv.DictWriter(f, fieldnames=['rank', 'title', 'rating', 'quote'])
writer.writeheader()
writer.writerows(movies)
print(f'CSV已保存: {filename}')
def save_to_json(movies, filename):
"""保存为JSON"""
with open(filename, 'w', encoding='utf-8') as f:
json.dump(movies, f, ensure_ascii=False, indent=2)
print(f'JSON已保存: {filename}')
def main():
os.makedirs('douban_output', exist_ok=True)
movies = crawl_douban_top10()
save_to_csv(movies, 'douban_output/movies.csv')
save_to_json(movies, 'douban_output/movies.json')
print('\n爬取结果:')
print('-' * 50)
for m in movies:
quote_text = f'{m["quote"]}' if m['quote'] else ''
print(f"{m['rank']}. {m['title']} - 评分: {m['rating']} {quote_text}")
print('\n完成!')
if __name__ == '__main__':
main()