この投稿 には、csvからxlsに変換するPythonの例があります。
ただし、私のファイルには65536行以上あるため、xlsは機能しません。ファイルにxlsxという名前を付けても違いはありません。 xlsxに変換するPythonパッケージはありますか?
xlsxwriter を使用した例を次に示します。
import os
import glob
import csv
from xlsxwriter.workbook import Workbook
for csvfile in glob.glob(os.path.join('.', '*.csv')):
workbook = Workbook(csvfile[:-4] + '.xlsx')
worksheet = workbook.add_worksheet()
with open(csvfile, 'rt', encoding='utf8') as f:
reader = csv.reader(f)
for r, row in enumerate(reader):
for c, col in enumerate(row):
worksheet.write(r, c, col)
workbook.close()
参考までに、Excel 2007 xlsx/xlsmファイルを読み書きできる openpyxl というパッケージもあります。
お役に立てば幸いです。
ライブラリpyexcel
を使用すると、
$ pip install pyexcel pyexcel-xlsx
1つのコマンドラインで実行できます。
from pyexcel.cookbook import merge_all_to_a_book
# import pyexcel.ext.xlsx # no longer required if you use pyexcel >= 0.2.2
import glob
merge_all_to_a_book(glob.glob("your_csv_directory/*.csv"), "output.xlsx")
各csvには独自のシートがあり、名前はファイル名になります。
from openpyxl import Workbook
import csv
wb = Workbook()
ws = wb.active
with open('test.csv', 'r') as f:
for row in csv.reader(f):
ws.append(row)
wb.save('name.xlsx')
pandasライブラリを使用して.csvファイルを読み取り、.xlsxファイルとして保存する回答を追加します。この例では、pandas.read_csv
( ドキュメントへのリンク )およびpandas.dataframe.to_Excel
( ドキュメントへのリンク )。
完全に再現可能な例では、numpyを使用して乱数のみを生成します。独自の.csvファイルを使用する場合は、これを削除できます。
import pandas as pd
import numpy as np
# Creating a dataframe and saving as test.csv in current directory
df = pd.DataFrame(np.random.randn(100000, 3), columns=list('ABC'))
df.to_csv('test.csv', index = False)
# Reading in test.csv and saving as test.xlsx
df_new = pd.read_csv('test.csv')
writer = pd.ExcelWriter('test.xlsx')
df_new.to_Excel(writer, index = False)
writer.save()
openpyxl libでどのように行うか:
import csv
from openpyxl import Workbook
def convert_csv_to_xlsx(self):
wb = Workbook()
sheet = wb.active
CSV_SEPARATOR = "#"
with open("my_file.csv") as f:
reader = csv.reader(f)
for r, row in enumerate(reader):
for c, col in enumerate(row):
for idx, val in enumerate(col.split(CSV_SEPARATOR)):
cell = sheet.cell(row=r+1, column=idx+1)
cell.value = val
wb.save("my_file.xlsx")
簡単な方法があります
import os
import csv
import sys
from openpyxl import Workbook
reload(sys)
sys.setdefaultencoding('utf8')
if __== '__main__':
workbook = Workbook()
worksheet = workbook.active
with open('input.csv', 'r') as f:
reader = csv.reader(f)
for r, row in enumerate(reader):
for c, col in enumerate(row):
for idx, val in enumerate(col.split(',')):
cell = worksheet.cell(row=r+1, column=c+1)
cell.value = val
workbook.save('output.xlsx')