Update: 初学记、佩文韵府 and 五车韵瑞

This commit is contained in:
denglifan
2026-03-22 16:18:35 +08:00
parent df475fd03f
commit 183b842090
553 changed files with 754048 additions and 169 deletions

View File

@@ -0,0 +1,65 @@
import os
import time
import urllib.parse
import requests
from requests.exceptions import RequestException
def main():
if not os.path.exists("html_files"):
os.makedirs("html_files")
with open("missing_urls.txt", "r", encoding="utf-8") as f:
urls = [line.strip() for line in f if line.strip()]
proxies = {"http": "http://127.0.0.1:10808", "https": "http://127.0.0.1:10808"}
headers = {
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36"
}
for url in urls:
# Decode the URL to get the original characters
decoded_url = urllib.parse.unquote(url)
# Extract the volume name, e.g., 卷001之1
volume_name = decoded_url.split("/")[-1]
filename = f"html_files/{volume_name}.html"
if os.path.exists(filename):
print(f"Skipping {filename}, already exists.")
continue
print(f"Downloading {volume_name} from {url}...")
success = False
retries = 3
while not success and retries > 0:
try:
response = requests.get(
url, headers=headers, proxies=proxies, timeout=15
)
if response.status_code == 200:
with open(filename, "w", encoding="utf-8") as out_f:
out_f.write(response.text)
success = True
print(f"Successfully downloaded {filename}")
else:
print(
f"HTTP Error {response.status_code} for {url}. Retries left: {retries - 1}"
)
except RequestException as e:
print(f"Error downloading {url}: {e}. Retries left: {retries - 1}")
if not success:
retries -= 1
time.sleep(2) # Delay before retry
if not success:
print(f"Failed to download {url} after all retries.")
time.sleep(0.5) # Small delay between requests
if __name__ == "__main__":
main()