質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

863閲覧

CSVファイルにヘッダーを追加したい

F91_

総合スコア16

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2023/02/15 13:41

編集2023/02/15 14:20

実現したいこと

システムに取り込み可能なcsvファイル形式に
誰でも自動変換可能なpythonexeファイルを作成したいです

前提

pythonにて会社の帳票エクセルファイルを読み込み、その中の一部をコピーし、
システムに取り込み可能な形式にて自動出力可能なexeファイルを作成したいです。

読み込むエクセルファイルは会社の帳票に内容を入力したものです。
現状、そのままの形式ではシステムに取り込みが出来ないので、
一定の条件を満たされた形式に手作業にてコピー&ペーストにて書き換えています。
コピー&ペースト作業を自動化したいので、
誰でも操作可能なexeファイルを作成します。

発生している問題・エラーメッセージ

システム取込csv用ファイルに必要なヘッダーを追加したいのですが、
以下のエラーメッセージが発生しました。

取り込み用ファイル※一部切り抜きしています
イメージ説明
目指しているファイル形式※一部切り抜きしています
イメージ説明

エラーメッセージ ['工程パターンコード', '行№', '工程№', '工程外径', '備考'] --------------------------------------------------------------------------- Error Traceback (most recent call last) <ipython-input-15-e091b70bd9cf> in <module> 31 wrtr=csv.writer(f,delimiter=',') 32 wrtr.writerow(header) # ヘッダーを書き込む ---> 33 wrtr.writerows(values) 34 f.close() 35 Error: iterable expected, not int ### 該当のソースコード ```python ソースコード import openpyxl import csv header = ['工程パターンコード', '行№','工程№', '工程外径','備考'] wb = openpyxl.load_workbook("1.xlsx") ws = wb.worksheets[0] for row in ws["C29:O48"]: values = [] for col in row: values.append(col.value) del values[4:9] del values[3:7] if values[2] is None: print(values) else: values[1]=values[0] f=open('取込'+'.csv','a',newline='') print(header) wrtr=csv.writer(f,delimiter=',') wrtr.writerow(header) # ヘッダーを書き込む wrtr.writerows(values) f.close()

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

melian

2023/02/15 13:57

おそらく、values は1行分のデータ(リスト)なので、writerows ではなく writerow ではないでしょうか。 wrtr.writerow(values)
meg_

2023/02/15 14:04

図を添付しようとしているようですが、表示されていません。確認の上修正お願いします。
F91_

2023/02/15 14:25

writerowに変更した所、エラーはなくなりました。しかし、繰り返し処理がwrtr.writerow(header)も適用されております。(位置的に当然ですが・・・) wrtr.writerow(header)はさせない方法などありますか?
melian

2023/02/15 14:31

for 文の外側へ移動させればよいのではないでしょうか。 wb = openpyxl.load_workbook("1.xlsx") ws = wb.worksheets[0] f=open('取込'+'.csv','a',newline='') wrtr=csv.writer(f,delimiter=',') wrtr.writerow(header) # ヘッダーを書き込む for row in ws["C29:O48"]: values = [] そして、f.close() は for ループが全て完了してから実行します。
F91_

2023/02/16 12:36

ありがとうございました。完璧です!
guest

回答1

0

自己解決

import openpyxl
import csv

header = ['工程パターンコード', '行№','工程№', '工程外径','備考']

wb = openpyxl.load_workbook("1.xlsx")
ws = wb.worksheets[0]
f=open('取込'+'.csv','a',newline='')
print(header)

wrtr=csv.writer(f,delimiter=',')
wrtr.writerow(header) # ヘッダーを書き込む

for row in ws["C29:O48"]:
values = []

for col in row: values.append(col.value) del values[4:9] del values[3:7] if values[2] is None: print(values) else: values[1]=values[0] wrtr.writerow(values)

f.close()

投稿2023/02/16 13:17

F91_

総合スコア16

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問