PDF Reports 项目使用教程

PDF Reports 项目使用教程

pdf_reports:closed_book: Python library and CSS theme to generate PDF reports from HTML/Pug项目地址:https://gitcode.com/gh_mirrors/pd/pdf_reports

1. 项目的目录结构及介绍

PDF Reports 项目的目录结构如下:

pdf_reports/
├── examples/
│   └── basic_example/
│       ├── example_template.pug
│       └── example.pdf
├── pdf_reports/
│   ├── __init__.py
│   ├── pug_to_html.py
│   ├── write_report.py
│   └── ...
├── tests/
│   └── ...
├── .gitignore
├── LICENSE
├── README.md
└── setup.py

目录结构介绍

  • examples/: 包含示例文件,如 basic_example/ 目录下的 example_template.pugexample.pdf
  • pdf_reports/: 项目的主要代码文件夹,包含核心功能的实现文件,如 pug_to_html.pywrite_report.py
  • tests/: 包含项目的测试文件。
  • .gitignore: Git 忽略文件配置。
  • LICENSE: 项目的开源许可证。
  • README.md: 项目的说明文档。
  • setup.py: 项目的安装配置文件。

2. 项目的启动文件介绍

项目的启动文件主要是 setup.py,它负责项目的安装和配置。以下是 setup.py 的基本内容:

from setuptools import setup, find_packages

setup(
    name='pdf_reports',
    version='0.1.0',
    packages=find_packages(),
    install_requires=[
        'pypugjs',
        'weasyprint',
        'semantic-ui'
    ],
    author='Zulko',
    author_email='your_email@example.com',
    description='A Python library to create nice-looking PDF reports from HTML or Pug templates',
    long_description=open('README.md').read(),
    long_description_content_type='text/markdown',
    url='https://github.com/Edinburgh-Genome-Foundry/pdf_reports',
    classifiers=[
        'License :: OSI Approved :: MIT License',
        'Programming Language :: Python :: 3',
        'Programming Language :: Python :: 3.6',
        'Programming Language :: Python :: 3.7',
        'Programming Language :: Python :: 3.8',
        'Programming Language :: Python :: 3.9',
    ],
)

启动文件介绍

  • setup.py: 使用 setuptools 进行项目的打包和安装,定义了项目的名称、版本、依赖包、作者信息等。

3. 项目的配置文件介绍

项目的配置文件主要是 pdf_reports/ 目录下的各个模块文件,如 pug_to_html.pywrite_report.py。以下是 pug_to_html.py 的基本内容:

from pypugjs import Compiler
from weasyprint import HTML

def pug_to_html(template_path, **kwargs):
    with open(template_path, 'r') as file:
        template_content = file.read()
    
    compiler = Compiler()
    html_content = compiler.compile(template_content)
    
    for key, value in kwargs.items():
        html_content = html_content.replace(f'[[ {key} ]]', str(value))
    
    return html_content

配置文件介绍

  • pug_to_html.py: 负责将 Pug 模板转换为 HTML 内容。
  • write_report.py: 负责将生成的 HTML 内容写入 PDF 文件。

这些文件定义了项目的主要功能和配置,用户可以根据需要进行修改和扩展。

pdf_reports:closed_book: Python library and CSS theme to generate PDF reports from HTML/Pug项目地址:https://gitcode.com/gh_mirrors/pd/pdf_reports

Java使用com.lowagie.text.pdf插件编写的PDF报表工具类,支持动态报表创建,使用简单,附件中包含了测试类和生成的报表文件。附件中的代码需要修改相关的保存路径后可以直接使用。创建一张报表例子: private JsFileExportResult createRowReport() { String condition = "开始时间:2018-02-02 14:00:30 结束时间:2018-02-06 16:00:30"; PDFGridReport pdfReport = new PDFGridReport("报表创建测试", GridReportTestModel.getModels()); pdfReport.addCondition(condition); pdfReport.header("字段名称1", "item1", 0, 0).width(160); pdfReport.header("字段名称3", "item3", 0, 2).getCell().backgroundColor(Color.ORANGE); pdfReport.header("字段名称4", "item4", 0, 3); pdfReport.header("字段名称5", "item5", 0, 4); pdfReport.header("字段名称2", "item2", 0, 1); pdfReport.header("值", "value", 0, 5).alignH(HAlign.ALIGN_CENTER).getCell().alignH(HAlign.ALIGN_RIGHT); pdfReport.header("时间", "time", 0, 6); pdfReport.header("图片", "image", 0, 7).width(60).alignH(HAlign.ALIGN_CENTER).getCell() .alignH(HAlign.ALIGN_CENTER).alignV(VAlign.ALIGN_MIDDLE); // 横向打印 pdfReport.getPageSetting().setPrintHorizontal(); pdfReport.group("item1").childGroup("item2"); pdfReport.setCellFormat(new PDFCellValueFormat() { @Override public String format(String fieldName, String oriValue) { if ("value".equals(fieldName)) { return String.format("%.2f", Double.parseDouble(oriValue)).toString(); } else { return oriValue; } } }); JsFileExportResult fileResult = pdfReport.createReport(); return fileResult; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

褚柯深Archer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值