csv.writer写入中文乱码
时间: 2023-07-07 08:03:21 浏览: 105
如果在使用`csv.writer`时遇到中文乱码问题,可以使用`codecs`库来指定文件编码格式。以下是一个示例代码:
```python
import csv
import codecs
with codecs.open('file.csv', 'w', 'utf-8') as f:
writer = csv.writer(f)
writer.writerow(['中文', 'English'])
writer.writerow(['你好', 'hello'])
```
在这个示例中,我们使用`codecs`库打开文件并指定编码格式为`utf-8`。然后,我们将这个文件对象传递给`csv.writer`,并使用`writer.writerow`方法写入中文和英文数据。由于我们指定了正确的编码格式,因此在写入文件时就不会出现中文乱码问题了。
相关问题
def write_csv_with_name(filepath, line: list, columns: list): if os.path.exists(filepath): with open(filepath, 'a', newline='', encoding='utf-8-sig') as f: csv_file = csv.writer(f, delimiter=',') csv_file.writerow(line) else: with open(filepath, 'a', newline='', encoding='utf-8-sig') as f: csv_file = csv.writer(f, delimiter=',') csv_file.writerow(columns) csv_file.writerow(line)
这是一个写入CSV文件的函数,它的参数包括文件路径(filepath)、要写入的内容(line)和CSV文件的列名(columns)。该函数首先判断文件路径是否存在,如果存在,则以追加模式打开文件,并使用csv.writer将内容写入CSV文件中;如果文件路径不存在,则以创建模式打开文件,并先写入列名,然后再写入内容。其中,newline=''参数表示使用默认的换行符,encoding='utf-8-sig'参数表示使用UTF-8编码格式,保证在Windows系统下打开CSV文件时不会出现中文乱码的情况。
优化这段代码#csv_combline #encoding = utf-8 import os import csv path = "D:\csv_test\\" for files in os.listdir(path): datas = [] #读取csv文件 for fname in os.listdir(path): if 'csv' in fname: fname_path = path + fname with open(fname_path,'r',encoding = 'latin1') as path: reader = csv.reader(path) #去掉表头第0行,从第一行开始copy数据 reader = list(reader)[1:] for line in render: datas.append(line) eccel_name = 'excle汇总.csv' csv_head = ['name','aaa','bbb'] with open(excel_name,'w') as path: writer = csv.writer(path) #写表头 writer.writerow(csv_head) writer.writerows(datas) print('exlce.csv合并完成')
优化建议如下:
1. 将代码块封装成一个函数,提高代码的可重用性和可维护性。
2. 将常量和变量的命名方式统一,便于代码的阅读和理解。
3. 将文件路径的拼接方式改为os.path.join()方法,增强代码的跨平台兼容性。
4. 使用with语句打开文件,可自动管理文件资源,不需要手动关闭文件,简化代码。
5. 将csv文件读取和写入的编码方式改为'utf-8',避免出现中文乱码问题。
6. 将写入csv文件的表头和数据分别存储在两个列表中,遵循“单一职责原则”,增强代码的可读性和可维护性。
7. 将读取csv文件的代码块修改为生成器表达式,节省内存开销。
8. 将写入csv文件的操作放在try...except块中,避免出现写入失败的情况。
优化后的代码如下所示:
```python
import os
import csv
def combine_csv_files(src_dir, dest_file):
csv_head = ['name', 'aaa', 'bbb']
data_rows = []
try:
for file_name in os.listdir(src_dir):
if file_name.endswith('.csv'):
file_path = os.path.join(src_dir, file_name)
with open(file_path, 'r', encoding='utf-8') as f:
reader = csv.reader(f)
next(reader) # skip header
data_rows.extend(reader) # append rows to data list
with open(dest_file, 'w', newline='', encoding='utf-8') as f:
writer = csv.writer(f)
writer.writerow(csv_head)
writer.writerows(data_rows)
print(f'CSV files in {src_dir} are combined into {dest_file}')
except Exception as e:
print(f'Error occurs: {e}')
if __name__ == '__main__':
src_dir = r'D:\csv_test'
dest_file = r'D:\csv_test\excle汇总.csv'
combine_csv_files(src_dir, dest_file)
```
阅读全文