Compare commits

..

No commits in common. "dev" and "main" have entirely different histories.
dev ... main

3 changed files with 77 additions and 132 deletions

View File

@ -2,18 +2,22 @@
## 功能
将当前文件夹中所有的子文件夹以`发票-付款记录-购买记录`为一组的三张图片放在`.docx`文件的同一页面。同时会生成相应的`.pdf`文件。
将当前文件夹中以`发票-付款记录-购买记录`为一组的三张图片放在`.docx`文件的同一页面。同时会生成相应的`.pdf`文件。
会将`.pdf`、`.jpg`、`.jpeg`文件自动转换为`.png`文件再插入。
## 使用方法
1. 将`.exe`文件与所有包含待处理图片的**子文件夹**放在同一个文件夹。
2. 运行`.exe`文件,根据提示进行操作。
1. 将`.exe`文件与待处理图片放在同一个文件夹。
## 注意事项
2. 文件夹中所有图片按照分组命名:【两位数字】【类型】【其余内容】。
1. 图片文件不得以 "pdf" 三个字母开头。
从01开始按顺序命名序号同组的文件序号相同类型发票a付款记录b购买记录c。
例如“02b公仔付款.png” -> 第二组的付款记录图片。
**一位数请在开头加上 0如 02、06。**
3. 运行`.exe`文件,根据提示进行操作。
## 所需包(已打包在`.exe`中)

195
main.py
View File

@ -1,137 +1,82 @@
from docx import Document
from docx.shared import Inches
from PIL import Image
from copy import copy
from PIL import Image
import fitz
from docx2pdf import convert
from sys import exit
import os
def done(exit_code = 0):
print("正在移除多余生成文件...")
for gen in gened_list:
os.remove(gen)
print("移除完毕!")
input("按回车键退出...")
exit(exit_code)
def convert_all(path = os.path.abspath('.')):
print("正在扫描并处理文件中...")
items = os.listdir(path)
for item in items:
if os.path.isdir(item):
result = convert_img(item, path + '\\' + item)
if result == 1:
print("PDF 转换失败!")
done(1)
elif result == 2:
def convert_img(path = os.path.abspath('.')):
while True:
print("正在扫描并处理文件中...")
files = os.listdir('.')
for file in files:
if file.endswith('.pdf') and "output" not in file:
result = pdf2img(path, file)
if result: # 1 -> Error
print("PDF 转换失败!")
continue
elif file.endswith('.jpg') or file.endswith('.jpeg'):
img = Image.open(file)
img.save(file.split('.')[0] + ".png", "PNG")
print("JPG/JPEG 转换失败!")
done(1)
print("转换完毕!")
"""传入绝对路径"""
def convert_img(dir_name, path = os.path.abspath('.')):
files = os.listdir(path)
pdf_list = []
for file in files:
file = file.lower() # 排除 .PNG 等带来的问题
if file.endswith('.pdf'):
result = pdf2img(path, file)
if result: # 1 -> Error
return 1
pdf_list.append(file)
elif file.endswith('.jpg') or file.endswith('.jpeg'):
img = Image.open(path + '\\' + file)
dot_index = file.rfind('.')
img_path = path + '\\' + file[:dot_index] + ".png"
img.save(img_path, "PNG")
gened_list.append(img_path)
if len(pdf_list) > 1:
print(f"注意到文件夹 {dir_name} 中有多个 .pdf 文件:")
for i in range(len(pdf_list)): # 打印 pdf 文件和选项
print(f"{i + 1} - {pdf_list[i]}") # 索引从 0 改为 1
while True:
invoice_index = input("请选择发票文件(输入选项前的阿拉伯数字):")
if not invoice_index.isdigit():
print("请输入数字!")
continue
else:
invoice_int = int(invoice_index) - 1 # 索引从 1 改为 0
if invoice_int < len(pdf_list) and invoice_int >= 0:
invoice_path = path + '\\' + "pdf" + pdf_list[invoice_int][:-4] + ".png"
invoice_renamed = path + '\\' + 'Pdf' + pdf_list[invoice_int][:-4] + ".png"
os.rename(invoice_path, invoice_renamed) # 将 "pdf" 标签变为 "Pdf"
gened_list.remove(invoice_path)
gened_list.append(invoice_renamed)
break
else:
print("请选择正确的序号!")
print("转换完毕!")
break
def gen_filelist(path = os.path.abspath('.')):
print("创建文件夹列表中...")
dir_list = []
item_list = os.listdir('.')
for item in item_list:
if os.path.isdir(item):
dir_list.append(item)
file_list = {}
for dir in dir_list:
file_list[dir] = os.listdir(path + '\\' + dir)
for dir, dir_file in file_list.items():
dir_file_copy = copy(dir_file)
for file in dir_file_copy:
if ".png" not in file.lower():
dir_file.remove(file)
if len(dir_file) != 3:
print(f"{dir}文件夹发现错误png文件个数不符")
for file in dir_file:
print('- ' + file)
if len(dir_file) == 2: # 说明有两个文件
option = input("文件夹仅有两个文件仍继续生成y/N").lower()
if option != 'y':
done(1)
types = "abc"
print("创建文件列表中...")
file_list = os.listdir('.')
file_list_cp = copy(file_list) # 创建浅拷贝
for filename in file_list_cp:
if ".png" not in filename:
file_list.remove(filename)
file_list.sort()
page_curr = 1
type_curr = 0
for filename in file_list:
if int(filename[0:2]) != page_curr or filename[2] != types[type_curr % 3]:
return []
else:
type_curr += 1
if type_curr % 3 == 0:
page_curr += 1
print("创建完毕!将要加入文档的文件如下:")
for dir, dir_file in file_list.items():
print('- ' + dir)
print(' ', end = '')
for file in dir_file:
print(file, end = ", ")
print()
print(f"共有 {len(list(file_list.items()))} 组文件")
for file in file_list:
print(file)
return file_list
def gen_docx(path = os.path.abspath('.')):
doc = Document()
file_list = gen_filelist()
input("按回车键确认...")
print("生成 .docx 文档中...")
if len(file_list) != 0:
for dir, dir_file in file_list.items():
parent_path = path + '\\' + dir + '\\'
for file in dir_file:
if file[0:3] == "Pdf":
dir_file.remove(file)
dir_file.insert(0, file) # 将发票文件放在第一个位置
doc.add_picture(parent_path + dir_file[0], height = Inches(2.5))
table = doc.add_table(rows = 1, cols = 2)
cell1 = table.cell(0, 0)
cell1.paragraphs[0].add_run().add_picture(parent_path + dir_file[1], height = Inches(5.0))
cell2 = table.cell(0, 1)
if len(dir_file) == 3:
cell2.paragraphs[0].add_run().add_picture(parent_path + dir_file[2], height = Inches(5.0))
if (dir, dir_file) != list(file_list.items())[-1]: # dict.items() 返回值需先转换为列表,才能索引
doc.add_page_break()
else:
print("请检查文件结构是否正确!")
done(1)
doc.save("output.docx")
print("生成完毕!")
def gen_docx():
while True:
doc = Document()
file_list = gen_filelist()
input("按回车键确认...")
print("生成 .docx 文档中...")
if len(file_list) != 0:
pic_count = 0
for filename in file_list:
pic_count += 1
if pic_count % 3 == 1:
doc.add_picture(filename, height = Inches(2.5))
table = doc.add_table(rows = 1, cols = 2)
elif pic_count % 3 == 2:
cell1 = table.cell(0, 0)
cell1.paragraphs[0].add_run().add_picture(filename, height = Inches(5.0))
elif pic_count % 3 == 0:
cell2 = table.cell(0, 1)
cell2.paragraphs[0].add_run().add_picture(filename, height = Inches(5.0))
if pic_count != len(file_list):
doc.add_page_break()
else:
print("请检查文件命名是否正确!")
doc.save("output.docx")
print("生成完毕!")
break
def pdf2img(pdf_path, pdf_name, zoom_x = 3, zoom_y = 3):
doc = fitz.open(pdf_path + "\\" + pdf_name) # 打开文档
@ -140,22 +85,18 @@ def pdf2img(pdf_path, pdf_name, zoom_x = 3, zoom_y = 3):
return 1
for page in doc: # 遍历页面
pix = page.get_pixmap(matrix=fitz.Matrix(zoom_x, zoom_y)) # 将页面渲染为图片
png_path = pdf_path + '\\' + "pdf" + pdf_name[:-4] + ".png"
gened_list.append(png_path)
pix.save(png_path) # 将图像存储为PNG格式
pix.save(pdf_name[:-4] + '.png') # 将图像存储为PNG格式
doc.close() # 关闭文档
if __name__ == "__main__":
gened_list = [] # 新创建的文件列表,在出错时或者生成完毕时进行删除
print("在使用该脚本前,请保证程序所在的文件夹中仅包含程序、发票文件夹")
print("并且确保每个发票文件夹内只有三个文件")
print("在使用该脚本前,请将发票、付款记录、购买记录按以下规则命名:")
print("在文件名前添加[两位数字][类型]")
print("数字代表的是第几份材料类型发票a付款记录b购买记录c")
print("02b小公仔付款.png 代表第二份材料中的付款记录")
input("按回车键开始...")
convert_all()
convert_img()
gen_docx()
print("生成 .pdf 文件中...")
convert("output.docx", "output.pdf")
print("生成完毕!")
done(0)

Binary file not shown.