Python(十七)excel指定列自动翻译成英文

前言

本章主要讲述在excel的指定列后面添加一列,并翻译成英文



一、效果图


二、代码

实际需求:

python 复制代码
# -*- codeing = utf-8 -*-
# @time: 2025/1/16  16:32
# @Author : Mikasa
#
# @Aim:自动将客户发的货物清单里的商品名称,翻译成英文;
#       并在当前excel中,品名后面加入一列,并将翻译后的英文写入到excel里

from translate import Translator
import pandas as pd

file_path = "./translate_packaging_list/test.xlsx"
sheet_name = "Sheet1"
column_name = "品名"
new_file_path = "./translate_packaging_list/test_translate.xlsx"


def extract_column_as_array(file_path, sheet_name, column_name):
    """
    获取excel某列数据,并返回一个list
    :param file_path:
    :param sheet_name:
    :param column_name:
    :return: 去掉空行的lsit
    """
    df = pd.read_excel(file_path, sheet_name=sheet_name)
    column_data = df[column_name].tolist()
    return column_data


def translate_text(text, src='zh-cn', dest='en'):
    """
    将中文翻译成英文
    :param text:
    :param src:
    :param dest:
    :return:
    """
    translator = Translator(from_lang=src, to_lang=dest)
    translation = translator.translate(text)
    return translation


def translate_packaging_list():
    """
    1、翻译后的值生成一个list
    2、在excel【品名】后加入一列【goods】列
    3、将翻译后的list写入到该列
    :return:
    """
    result_array = extract_column_as_array(file_path, sheet_name, column_name)  # 获取列表
    df = pd.read_excel(file_path, sheet_name=sheet_name)
    new_column_name = "goods"
    new_loc = df.columns.get_loc('品名') + 1 #获取指定列后面的坐标
    english_cargo_name_list = []
    for good_name in result_array:
        if type(good_name) == str:
            translated_text = translate_text(good_name)
            print(f"{good_name} -> {translated_text}")
            english_cargo_name_list.append(translated_text)
        else:
            english_cargo_name_list.append(good_name)
    print("english_cargo_name_list:", english_cargo_name_list)
    print("new_loc:", new_loc)
    df.insert(loc=new_loc, column=new_column_name, value=english_cargo_name_list)
    df.to_excel(new_file_path, index=False)


if __name__ == '__main__':
    translate_packaging_list()
相关推荐
2501_9216494914 分钟前
2026个人量化交易免费数据API接入:从选型到实操
经验分享·python·金融·api·个人开发·量化交易
wgzrmlrm7420 分钟前
如何解决ORA-28040没有匹配的验证协议_sqlnet.ora版本兼容设置
jvm·数据库·python
维度攻城狮20 分钟前
pycallgraph2drawio:Python 调用链可视化 + Draw.io 自由编辑
开发语言·python·draw.io·graphviz
极光代码工作室31 分钟前
基于NLP的智能客服系统设计与实现
python·深度学习·机器学习·ai·自然语言处理
Mr_Xuhhh34 分钟前
深入Java多线程进阶:从锁策略到并发工具全解析
前端·数据库·python
开开心心就好1 小时前
能把网页藏在Word里的实用摸鱼工具
linux·运维·服务器·windows·随机森林·逻辑回归·excel
apcipot_rain1 小时前
Python实战——蒙特卡洛模拟分析杀牌游戏技能收益
python·游戏·数学建模
老绿光1 小时前
Python 字典完全指南:从入门到实战
linux·服务器·python
是小蟹呀^1 小时前
【总结】LangChain中如何维持记忆
python·langchain·memory
蓝色的杯子1 小时前
OpenClaw一文详细了解-手搓OpenClaw-4 Tool Runtime
人工智能·python