AWSLambda:创建和下载EXCEL文件时出现编码问题
创始人
2024-11-19 09:30:10
0

AWS Lambda 会在导出 Excel 文件时遇到编码问题,这通常是因为缺乏相应的本地库和字体。通过在 Lambda 函数中安装 openpyxl 和 xlwt 库,并在函数中添加字体路径,可以解决此问题。

确保在 AWS Lambda 环境中安装了以下 Python 包:

  • openpyxl
  • xlwt

在 Lambda 函数的代码中,可以通过设置以下字体路径解决编码问题:

import os import openpyxl from openpyxl.utils import get_column_letter from openpyxl.styles import Font

设置字体路径

FONT_NAME = 'Droid Sans Fallback' FONT_PATH = os.path.exists('/usr/share/fonts/truetype') and '/usr/share/fonts/truetype' or
os.path.abspath(os.path.join(os.path.dirname(file), 'fonts')) if not os.path.exists(FONT_PATH): FONT_PATH = None

def create_excel_file(data): # 创建 Excel 文件 try: wb = openpyxl.Workbook() # 添加一个工作表 ws = wb.active

    # 设置表头
    headers = ['ID', 'Name', 'Email']
    for col_num, column_title in enumerate(headers, 1):
        column_letter = get_column_letter(col_num)
        ws['{}1'.format(column_letter)].font = Font(size=14, bold=True)
        ws['{}1'.format(column_letter)] = column_title

    # 添加数据
    for row_num, row_data in enumerate(data, 2):
        ws.cell(row=row_num, column=1).value = row_data.get('id')
        ws.cell(row=row_num, column=2).value = row_data.get('name')
        ws.cell(row=row_num, column=3).value = row_data.get('email')

    # 保存文件
    file_path = '/tmp/my_excel_file.xlsx'
    wb.save(file_path)

    return file_path

except Exception as e:
    print(e)
    return None

请注意:如果您需要在 Lambda 函数中处理某些非 ASCII 字符,例如中文字符,还需要将字符编码为 UTF-8。例如:

ws.cell(row=row_num, column=2).value = row_data.get('name').encode('utf-8')

相关内容

热门资讯

6分钟辅助!hhpoker是真... 6分钟辅助!hhpoker是真的假的,hhpoker真的有透视吗,演示教程(真是有挂)1、每一步都需...
第七分钟辅助!we poker... 第七分钟辅助!we poker插件,we poker免费辅助器,手筋教程(有挂方式)暗藏猫腻,小编详...
七分钟辅助!aa poker辅... 七分钟辅助!aa poker辅助包,pokemmo脚本辅助器下载,讲义教程(有挂秘籍)1、pokem...
第四分钟辅助!wepoker辅... 第四分钟辅助!wepoker辅助器安装包定制,aapoker透视脚本,大纲教程(有挂总结)所有人都在...
第四分钟辅助!wpk透视辅助靠... 第四分钟辅助!wpk透视辅助靠谱吗,wepoker透视苹果系统,诀窍教程(有挂猫腻);运wepoke...
七分钟辅助!aapoker透视... 七分钟辅助!aapoker透视脚本入口,wejoker开挂,学习教程(有挂教程)1、打开软件启动之后...
第四分钟辅助!淘宝买wepok... 第四分钟辅助!淘宝买wepoker透视有用吗,wpk俱乐部怎么作弊,积累教程(有挂规律)1、下载好淘...
6分钟辅助!we-poker软... 6分钟辅助!we-poker软件,购买的wpk辅助在哪里下载,积累教程(有挂技巧)购买的wpk辅助在...
第2分钟辅助!如何下载wepo... 第2分钟辅助!如何下载wepoker安装包,newpoker怎么安装脚本,教程书教程(今日头条)1、...
4分钟辅助!wepoker钻石... 4分钟辅助!wepoker钻石怎么看底牌,wepoker辅助器有哪些功能,法门教程(有挂详细)该软件...