【Python】Excel表格操作:ISBN转条形码

一、效果

原始文件:

输出文件:

二、代码

python 复制代码
import os
import logging
from openpyxl import load_workbook
from openpyxl.drawing.image import Image as ExcelImage
from barcode import EAN13
from barcode.writer import ImageWriter

logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')


def delete_files(directory):
    file_list = os.listdir(directory)
    for file in file_list:
        file_path = os.path.join(directory, file)
        if os.path.isfile(file_path):
            os.remove(file_path)


def generate_barcode_image_with_text(barcode_str, output_path_without_ext):
    # Generate barcode image without text
    ean = EAN13(barcode_str, writer=ImageWriter())
    saved_path = ean.save(output_path_without_ext)

    return saved_path


def insert_barcodes_to_excel(excel_file, ISBNCol, imgCol):
    logging.info("开始处理")

    if not os.path.exists('barcode_temp'):
        os.makedirs('barcode_temp')

    wb = load_workbook(excel_file)
    ws = wb.active
    logging.info(f"加载工作表: {ws.title}")

    img_height_in_points = 45  # 你设置的图片高度,单位是磅,1磅约等于1.33像素

    for row in range(2, ws.max_row + 1):
        barcode_cell = ws.cell(row=row, column=ISBNCol)
        barcode_str = str(barcode_cell.value).strip()
        if not barcode_str or len(barcode_str) != 13 or not barcode_str.isdigit():
            logging.warning(f"第{row}行条码格式不正确,跳过: {barcode_str}")
            continue

        img_path_no_ext = os.path.join('barcode_temp', f'barcode_{barcode_str}')
        try:
            img_path = generate_barcode_image_with_text(barcode_str, img_path_no_ext)
        except Exception as e:
            logging.error(f"生成条码失败,行{row},条码{barcode_str},错误: {e}")
            continue

        img_for_excel = ExcelImage(img_path)
        img_for_excel.width = 180
        img_for_excel.height = 60

        img_cell = f'{imgCol}{row}'

        # # 设置列宽
        ws.column_dimensions[imgCol].width = img_for_excel.width * 0.15
        # # 设置行高
        ws.row_dimensions[row].height = img_for_excel.height

        ws.add_image(img_for_excel, img_cell)

        # 调整当前行高,避免图片重叠
        current_height = ws.row_dimensions[row].height
        if current_height is None or current_height < img_height_in_points:
            ws.row_dimensions[row].height = img_height_in_points

        # logging.info(f"插入条码图片到 {img_cell} 并调整行高")

    new_file = os.path.splitext(excel_file)[0] + '_with_barcodes.xlsx'
    try:
        wb.save(new_file)
        logging.info(f"保存新文件: {new_file}")
    except PermissionError:
        logging.error(f"保存文件失败,可能文件被打开: {new_file}")

    if os.path.exists('barcode_temp'):
        logging.info("删除临时文件")
        delete_files('barcode_temp')

    logging.info("完成处理!")


if __name__ == "__main__":
    excel_path = 'D:\\temp\\图书清单.xlsx'
    insert_barcodes_to_excel(excel_path, 1, "B")

三、说明

1、insert_barcodes_to_excel参数1:原始Excel表格文件绝对路径。

2、insert_barcodes_to_excel参数2:ISBN所在列,数字格式。例如:ISBN在A列则输入1,在B列则输入2。

3、insert_barcodes_to_excel参数3:生成的条形码需要放在第几列,大写字母格式。例如:需要放在第二列则输入B,第三列则输入C。

相关推荐
Rock_yzh3 小时前
AI学习日记——参数的初始化
人工智能·python·深度学习·学习·机器学习
青衫客365 小时前
基于 Python 构建的安全 gRPC 服务——TLS、mTLS 与 Casbin 授权实战
python·安全·微服务
-dzk-6 小时前
【3DGS复现】Autodl服务器复现3DGS《简单快速》《一次成功》《新手练习复现必备》
运维·服务器·python·计算机视觉·3d·三维重建·三维
摩羯座-185690305947 小时前
爬坑 10 年!京东店铺全量商品接口实战开发:从分页优化、SKU 关联到数据完整性闭环
linux·网络·数据库·windows·爬虫·python
ACERT3337 小时前
5.吴恩达机器学习—神经网络的基本使用
人工智能·python·神经网络·机器学习
韩立学长7 小时前
【开题答辩实录分享】以《基于python的奶茶店分布数据分析与可视化》为例进行答辩实录分享
开发语言·python·数据分析
2401_831501738 小时前
Python学习之day03学习(文件和异常)
开发语言·python·学习
可触的未来,发芽的智生8 小时前
触摸未来2025.10.06:声之密语从生理构造到神经网络的声音智能革命
人工智能·python·神经网络·机器学习·架构
Zwb2997928 小时前
Day 24 - 文件、目录与路径 - Python学习笔记
笔记·python·学习
hui函数9 小时前
python全栈(基础篇)——day03:后端内容(字符串格式化+简单数据类型转换+进制的转换+运算符+实战演示+每日一题)
开发语言·后端·python·全栈