python 写一个批量xls格式的文件另存为
时间: 2024-06-11 16:06:27 浏览: 14
这里提供一个示例代码,可以将一个文件夹中的所有xls格式文件另存为xlsx格式文件。
```python
import os
import xlrd
import openpyxl
# 定义要处理的文件夹路径
folder_path = "path/to/folder"
# 遍历文件夹中的所有文件
for filename in os.listdir(folder_path):
file_path = os.path.join(folder_path, filename)
# 判断文件是否为xls格式
if filename.endswith(".xls"):
print(f"Converting {filename}...")
# 用xlrd读取xls文件
book = xlrd.open_workbook(file_path)
sheet = book.sheet_by_index(0)
data = [sheet.row_values(i) for i in range(sheet.nrows)]
# 新建一个xlsx文件
new_filename = filename.replace(".xls", ".xlsx")
new_file_path = os.path.join(folder_path, new_filename)
# 用openpyxl写入xlsx文件
wb = openpyxl.Workbook()
ws = wb.active
for row in data:
ws.append(row)
wb.save(new_file_path)
print(f"{new_filename} saved.\n")
```
说明:
1. `os.listdir()` 方法可以列出一个文件夹中所有的文件和文件夹,返回一个列表。
2. `os.path.join()` 方法可以将文件夹路径和文件名拼接成完整的文件路径。
3. `xlrd` 是一个读取Excel文件的第三方库,可以用来读取xls格式的文件。
4. `openpyxl` 是一个写入Excel文件的第三方库,可以用来写入xlsx格式的文件。
5. 代码中用 `xlrd` 读取xls文件,将数据保存在一个二维列表 `data` 中,然后用 `openpyxl` 新建一个xlsx文件,将 `data` 中的数据写入到文件中。
6. 文件名的处理:用字符串的 `replace()` 方法将文件名中的 ".xls" 替换为 ".xlsx",得到新的文件名。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![py](https://img-home.csdnimg.cn/images/20210720083646.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)