吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 3139|回复: 65
收起左侧

[Python 原创] 行业标准信息pdf下载

  [复制链接]
快乐的小萌新 发表于 2024-6-12 08:43
本帖最后由 快乐的小萌新 于 2024-9-7 18:26 编辑

行业标准信息服务平台pdf下载
网址:aHR0cHMlM0EvL2hiYmEuc2FjaW5mby5vcmcuY24v
利用图片一张一张加载爬取
页面从0开始,到最后一页
需要安装 Pillow 库首先,
确保你已经安装了 Python。然后,你可以使用pip命令来安装 Pillow 库。
在命令行中输入以下命令:pip install pillow
image.png


需要箭头位置的那一串字符,填入代码的name里面
image.png image.png


改了一版,以前404就直接结束
行业标准信息v2.zip (1.94 KB, 下载次数: 78) 蓝奏云:https://xiaopu1314.lanzout.com/ii9EJ29fw3na

免费评分

参与人数 11吾爱币 +18 热心值 +9 收起 理由
dingopark + 1 + 1 谢谢@Thanks!
soiomn + 1 + 1 谢谢@Thanks!
ookk + 1 + 1 热心回复!
苏紫方璇 + 7 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!
Bugott + 1 我很赞同!
艺路是蓝 + 2 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
wangzhu3366 + 1 我很赞同!
Atnil + 1 + 1 谢谢@Thanks!
helian147 + 1 + 1 热心回复!
小kgg + 1 + 1 lz牛逼
ll090822 + 1 + 1 热心回复!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

Kls673M 发表于 2024-6-12 16:18
本帖最后由 Kls673M 于 2024-6-12 16:21 编辑
txq0211 发表于 2024-6-12 10:00
之前也写了个,只是还在研究pyqt做界面,没分享,可以相互参考下。
[Python] 纯文本查看 复制代码
import pars ...[/quote]
[mw_shl_code=asm,true]

#借用下大佬的代码,补个简易UI,献丑了。……不会调版,这能这样了

import tkinter as tk
import parsel
import requests
from PIL import Image
import os
import re
from PyPDF2 import PdfMerger
import json

# 下载图片
def download_image(url, filename):
    os.makedirs(os.path.dirname(filename), exist_ok=True)  # 创建目录
    response = requests.get(url)
    with open(filename, 'wb') as file:
        file.write(response.content)

# 删除文件夹下所有文件
def delete_files_in_folder(folder_path):
    for filename in os.listdir(folder_path):
        file_path = os.path.join(folder_path, filename)
        if os.path.isfile(file_path):
            os.remove(file_path)

# 删除文件夹
def remove_folder(path):
    if os.path.exists(path):
        if os.path.isfile(path) or os.path.islink(path):
            os.remove(path)
        else:
            for filename in os.listdir(path):
                remove_folder(os.path.join(path, filename))
            os.rmdir(path)

def trans_jpg2pdf(jpg_list: list, tmpdir: str) -> list:
    """jpg图片转换成pdf
 
    Args:
        jpg_list (list): 图片文件列表
        tmpdir (str): 临时目录路径
 
    Returns:
        list: 图片转换后的pdf文件列表
    """
    pdf_list = []
    for jpg in jpg_list:
        jpg_path = os.path.join(images_dir, jpg)
        pdf_file = jpg.replace('.png', '.pdf')
        pdf_path = os.path.join(tmpdir, pdf_file)
        if os.path.exists(pdf_path):
            os.remove(pdf_path)
        pdf_list.append(pdf_path)
        im = Image.open(jpg_path)
        im.save(pdf_path, 'PDF', resolution=100.0)
    return pdf_list
 
def merge_pdf(pdf_list: list, result_pdf):
    """ 合并pdf文件
    Args:
        pdf_list (list): pdf文件列表
        result_pdf (str): 合并后的pdf文件名称
    """
    sorted_list = sorted(pdf_list, key=lambda x: int(re.search(r'\d+', x).group()))
    f_merger = PdfMerger()
    for pdf in sorted_list:
        f_merger.append(pdf)
    if os.path.exists(result_pdf):
        os.remove(result_pdf)
    with open(result_pdf, 'wb') as f:
        f_merger.write(f)
    f_merger.close()  # 将 close() 移动到写入操作之后

def getUrl(url):
    response = requests.get(url)
    return response
 
def getPage(current,key):
    headers = {
        "User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:126.0) Gecko/20100101 Firefox/126.0",
        "Content-Type": "application/x-www-form-urlencoded",
        "Referer": "https://hbba.sacinfo.org.cn/stdList",
    }
    url = "https://hbba.sacinfo.org.cn/stdQueryList"
    data = {
        "current": f"{current}",
        "size": "100",
        "key": f"{key}",
        "status": "现行"
    }
    response = requests.post(url, headers=headers, data=data)
    return response

def search():
    global records  # 声明records为全局变量
    keyword = entry_keyword.get()
    getJson = json.loads(getPage(1, keyword).text)
    pages = getJson["pages"]
    records = getJson["records"]
    listbox_results.delete(0, tk.END)
    for i, record in enumerate(records):
        chName = record["chName"]
        code = record["code"]
        listbox_results.insert(tk.END, f'{i+1} 《{chName}》{code}')

def download_selected():
    selected_index = listbox_results.curselection()
    if selected_index:
        getNum = selected_index[0]
        getId = records[getNum]["pk"]
        chName = records[getNum]["chName"]
        code = records[getNum]["code"].replace('/', ' ')
        titleUrl = f'https://hbba.sacinfo.org.cn/stdDetail/{getId}'
        selector = parsel.Selector(getUrl(titleUrl).text)
        title = f'《{chName}》{code}'
        url = 'https://hbba.sacinfo.org.cn/' + selector.css('h4 a::attr(href)').get()
        if url:
            html = getUrl(url).text
            numbers = re.findall(r'parseInt\(\'\d+\'\),', html)[0]
            number = re.findall(r'\d+', numbers)[0]
            key = url.split('/')[-1]

            for i in range(int(number)):
                pngUrl = f'https://hbba.sacinfo.org.cn/hbba_onlineRead_page/{key}/{i}.png'
                # 下载并保存图片
                filename = os.path.basename(pngUrl)
                download_image(pngUrl, f'images/{filename}')
                print(f'已缓存第{i}页')
            tmpdir = "temp"
            if not os.path.exists(tmpdir):
                # 如果不存在,创建目录
                os.mkdir(tmpdir)
            jpg_list = [f for f in os.listdir(images_dir) if f.endswith(".png")]
            pdf_list = trans_jpg2pdf(jpg_list, tmpdir)
            merge_pdf(pdf_list, f"{title}.pdf")
            print(f'已保存{title}.pdf')
            remove_folder(images_dir)
            remove_folder(tmpdir)
            print(f'已清理缓存页面')
        else:
            print('版权原因不公开,无法下载!')

# Create main window
root = tk.Tk()
root.title("行业标准文件 PDF下载")

images_dir = "images"
if not os.path.exists(images_dir):
    # 如果不存在,创建目录
    os.mkdir(images_dir)

# Create search frame
frame_search = tk.Frame(root)
frame_search.pack(pady=10)

# Label and entry for keyword
label_keyword = tk.Label(frame_search, text="名称:")
label_keyword.grid(row=0, column=0)
entry_keyword = tk.Entry(frame_search, width=30)
entry_keyword.grid(row=0, column=1)

# Search button
button_search = tk.Button(frame_search, text="搜索", command=search)
button_search.grid(row=0, column=2, padx=10)

# Create results frame
frame_results = tk.Frame(root)
frame_results.pack(pady=10)

# Listbox to display search results
listbox_results = tk.Listbox(frame_results, width=50, height=10)
listbox_results.pack(side=tk.LEFT, fill=tk.BOTH, expand=True)

# Scrollbar for listbox
scrollbar_results = tk.Scrollbar(frame_results)
scrollbar_results.pack(side=tk.RIGHT, fill=tk.Y)

# Configure scrollbar and listbox
listbox_results.config(yscrollcommand=scrollbar_results.set)
scrollbar_results.config(command=listbox_results.yview)

# Create download button
button_download = tk.Button(root, text="下载PDF", command=download_selected)
button_download.pack(pady=10)

root.mainloop()

免费评分

参与人数 1热心值 +1 收起 理由
zzf520 + 1 用心讨论,共获提升!

查看全部评分

 楼主| 快乐的小萌新 发表于 2024-6-12 08:56
BoyInTheSun 发表于 2024-6-12 08:53
之前我爬了国家标准的,全站资源下载,结账我到手才四百

我爬那个基金的80多万条数据,代码都跑了两天,结果别人不要了,开始要的只是200
BoyInTheSun 发表于 2024-6-12 08:50
强的
可惜需要的人大概率找不到甚至不会用,花钱找人搞,然后他们再二道贩子空手套白狼
 楼主| 快乐的小萌新 发表于 2024-6-12 08:51
BoyInTheSun 发表于 2024-6-12 08:50
强的
可惜需要的人大概率找不到甚至不会用,花钱找人搞,然后他们再二道贩子空手套白狼

这个没办法,我也想接这些简单的业务,也找不到
BoyInTheSun 发表于 2024-6-12 08:53
快乐的小萌新 发表于 2024-6-12 08:51
这个没办法,我也想接这些简单的业务,也找不到

之前我爬了国家标准的,全站资源下载,结账我到手才四百
小kgg 发表于 2024-6-12 08:53
只能说lz牛逼。。国标平台的国标好整。。这个行标还真不好整下来。。
youseitei 发表于 2024-6-12 08:53
很有用,感谢分享。
 楼主| 快乐的小萌新 发表于 2024-6-12 08:55
小kgg 发表于 2024-6-12 08:53
只能说lz牛逼。。国标平台的国标好整。。这个行标还真不好整下来。。

这个很简单啊,就是一张张图片下载,最后转换成pdf,都没加密的
newcools521 发表于 2024-6-12 09:04
随便找了几个  标准网站上都能下载下来。。,
 楼主| 快乐的小萌新 发表于 2024-6-12 09:05
newcools521 发表于 2024-6-12 09:04
随便找了几个  标准网站上都能下载下来。。,

我也只是测试了几个,能下载我就发了
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-15 19:12

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表