python3批量转换文件编码(python批量转换utf8)

本文目录一览:

python3编码转换

python3 \u53cc\u7684(双的)直接变成中文啊,你其他哪里出问题了吧

怎样将xlsx文件用Python脚本转成csv文件编码为UTF-8

策划的配置表为 xlsx 表格,可以有注释,公式。

服务器和客户端使用的配置文件需要转成 csv 文件。

使用 WPS 另存无法批量转换,并且结果不是utf8编码的,还需要用Notepad++转编码。

除了 xlsx 转为 csv, 其他格式文件保持原样,如 *.ini, *.xml, *.lua.

server/ 子目录特殊处理,不能复制到客户端。

用python脚本实现,依赖 openpyxl 库。

#!/usr/bin/env python

# coding: utf-8

# datatab.py

# 从策划配置表目录 game\Design\配置表\”

# 生成服务器的 game\Program\server\six\datatab\” 目录,

# 和客户端的 game\Program\client\Assets\Config\” 目录。

# 所有xlsx文件生成csv文件,其他文件原样复制。

# 其中 server\ 目录特殊处理,仅对服务器有效,客户端跳过。

#

# 依赖openpyxl库:

# 参考代码

# 测试环境:Python3.4

# Usage: datatab.py game dir

# Example: datatab.py “d:\game”

# game dir 是根目录,包含Design/, Program/ 目录。

from openpyxl import Workbook

from openpyxl.compat import range

from openpyxl.cell import get_column_letter

from openpyxl import load_workbook

import csv

import os

import sys

import shutil

def xlsx2csv(filename):

# try:

xlsx_file_reader = load_workbook(filename = filename, data_only = True)

for sheet in xlsx_file_reader.get_sheet_names():

# 仅第1个sheet输出到一个csv文件中,文件名后缀替换为.csv

csv_filename = os.path.splitext(filename)[0] + ‘.csv’

csv_file = open(csv_filename, ‘w’, encoding=’utf8′, newline=”)

csv_file_writer = csv.writer(csv_file)

sheet_ranges = xlsx_file_reader[sheet]

for row in sheet_ranges.rows:

row_container = []

for cell in row:

row_container.append(cell.value)

csv_file_writer.writerow(row_container)

# End of for row.

csv_file.close()

break # 仅输出第1个sheet

# End of for sheet.

# End of try.

# except Exception as e:

# print(e)

# End of xlsx2csv().

def datatab_convert(game_dir):

”’从 game\Design\配置表\ 输出到

game\Program\server\six\datatab\

game\Program\client\Assets\Config\

”’

design_dir = os.path.join(game_dir, ‘Design/配置表/’)

server_dir = os.path.join(game_dir, ‘Program/server/six/datatab/’)

client_dir = os.path.join(game_dir, ‘Program/client/Assets/Config/’)

# 删除旧文件。

print(“Delete ” + server_dir)

try:

shutil.rmtree(server_dir)

except:

pass

print(“Delete ” + client_dir)

try:

shutil.rmtree(client_dir)

except:

pass

# 生成server文件

print(“Creating ” + server_dir)

shutil.copytree(design_dir, server_dir)

files = get_files(server_dir)

convert_files(files)

# 复制client文件

print(“Copy ” + client_dir)

shutil.copytree(server_dir, client_dir)

shutil.rmtree(os.path.join(client_dir, ‘server/’))

print(“Done. Total files: %d” % len(files))

# End of datatab_convert().

def get_files(dir):

”’Get a list of files under input dir.”’

result = []

for root,dirs,files in os.walk(dir):

for f in files:

result.append(os.path.join(root, f))

return result

# End of get_files().

def convert_files(files):

”’转换一批文件.

files 是列表,元素为完整路径名。

”’

for f in files:

ext = os.path.splitext(f)[1].lower()

if ‘.xlsx’ != ext:

print(f + ” – keep”)

continue

print(f + ” – csv”)

xlsx2csv(f)

os.remove(f)

# End of convert_files().

if __name__ == ‘__main__’:

if len(sys.argv) != 2:

print(‘usage: datatab game dir’)

else:

datatab_convert(sys.argv[1])

sys.exit(0)

# Usage: datatab.py game dir

# Example: datatab.py “d:\game”

# game dir 是SVN根目录,包含Design/, Program/ 目录。

为方便使用,将datatab.py 打包成 exe, 这样不能安装Python就能运行。

下载并安装Python3, 安装openpyxl包,保证本地可以运行 datatab.py.

下载并安装PyInstaller:

pip install pyinstaller

运行

pyinstaller –onefile datatab.py

ImportError: No module named ‘jdcal’

可能openpyxl安装时自带的jdcal无法找到,删除

C:\Python34\Lib\site-packages\jdcal-1.0-py3.4.egg

重新安装:pip install jdcal

怎么通过Python将一个目录下的所有txt文件全部从ASCII编码转换为UTF-8(或Unicode)编码

记事本的另存就有这功能吧?

编码方式缺省的是ANSI,可以选择Unicode/Unicode big endian/UTF-8

原创文章,作者:LHVMT,如若转载,请注明出处:https://www.506064.com/n/128889.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
LHVMTLHVMT
上一篇 2024-10-03 23:25
下一篇 2024-10-03 23:25

相关推荐

  • Python计算阳历日期对应周几

    本文介绍如何通过Python计算任意阳历日期对应周几。 一、获取日期 获取日期可以通过Python内置的模块datetime实现,示例代码如下: from datetime imp…

    编程 2025-04-29
  • 如何查看Anaconda中Python路径

    对Anaconda中Python路径即conda环境的查看进行详细的阐述。 一、使用命令行查看 1、在Windows系统中,可以使用命令提示符(cmd)或者Anaconda Pro…

    编程 2025-04-29
  • Python周杰伦代码用法介绍

    本文将从多个方面对Python周杰伦代码进行详细的阐述。 一、代码介绍 from urllib.request import urlopen from bs4 import Bea…

    编程 2025-04-29
  • Python列表中负数的个数

    Python列表是一个有序的集合,可以存储多个不同类型的元素。而负数是指小于0的整数。在Python列表中,我们想要找到负数的个数,可以通过以下几个方面进行实现。 一、使用循环遍历…

    编程 2025-04-29
  • Python中引入上一级目录中函数

    Python中经常需要调用其他文件夹中的模块或函数,其中一个常见的操作是引入上一级目录中的函数。在此,我们将从多个角度详细解释如何在Python中引入上一级目录的函数。 一、加入环…

    编程 2025-04-29
  • Python字典去重复工具

    使用Python语言编写字典去重复工具,可帮助用户快速去重复。 一、字典去重复工具的需求 在使用Python编写程序时,我们经常需要处理数据文件,其中包含了大量的重复数据。为了方便…

    编程 2025-04-29
  • Python清华镜像下载

    Python清华镜像是一个高质量的Python开发资源镜像站,提供了Python及其相关的开发工具、框架和文档的下载服务。本文将从以下几个方面对Python清华镜像下载进行详细的阐…

    编程 2025-04-29
  • python强行终止程序快捷键

    本文将从多个方面对python强行终止程序快捷键进行详细阐述,并提供相应代码示例。 一、Ctrl+C快捷键 Ctrl+C快捷键是在终端中经常用来强行终止运行的程序。当你在终端中运行…

    编程 2025-04-29
  • Python程序需要编译才能执行

    Python 被广泛应用于数据分析、人工智能、科学计算等领域,它的灵活性和简单易学的性质使得越来越多的人喜欢使用 Python 进行编程。然而,在 Python 中程序执行的方式不…

    编程 2025-04-29
  • 蝴蝶优化算法Python版

    蝴蝶优化算法是一种基于仿生学的优化算法,模仿自然界中的蝴蝶进行搜索。它可以应用于多个领域的优化问题,包括数学优化、工程问题、机器学习等。本文将从多个方面对蝴蝶优化算法Python版…

    编程 2025-04-29

发表回复

登录后才能评论