
すいません質問があります。
pythonでリストをCSVに出力する際に、インデックスごとに改行したいです。
下記のPythonのコードを実行すると、
CSV内で、
abc,def と A1, A2に配置されてしまいます。
しかし、今回やりたいのは、
abc
def
とすることです。
そのやり方をぜひとも教えてほしいです。
import csv
csvlist = ["abc","def"]
f = open("output.csv", "w")
writecsv = csv.writer(f, lineterminator='\n')
writecsv.writerow(csvlist)
f.close()
お手数をおかけしますがよろしくお願いいたします。
No.5ベストアンサー
- 回答日時:
#1の方法は
for x in csvlist:write:
で リストの1要素を取り出し
csv.writerow(x)
でcsvとして書き込んでいます。
このとき、 x は csvlistの1要素なので「文字列」です。
文字列は「1文字ずつが並んだシーケンシャル」として解釈されます。
csvwriter.writerowメソッドは、「シーケシャルデータを受け取って、その各要素をdelimiterで指定した文字で区切って出力する」というものです。
つまり、 csv.writerow(x) では「 xの文字列を1文字ずつカンマに区切って出力」することになります。
出力したいのは x そのものなのですから、writerowには「 要素が x 一つだけのシーケンシャル」を指定する必要があります。
例えば csv.writerow( (x,) ) とタプルにする、等。
で、そんな面倒なことするよりは、f.writeメソッドを使って f.write(x + '\n') とでもした方がいいのではないでしょうか。
csvモジュールを使う必要はありません。
No.3
- 回答日時:
lineterminator は改行コードを指定するもので、 カンマを改行に変更すうものではありません。
区切りを変えるのは delimiter です。
ただ、リストの内容を改行して出力したい、というだけならcsvモジュールを使う必要は無く、
・for で 1つずつ 改行付けて出力
・ https://docs.python.org/ja/3/library/stdtypes.ht … を使って改行で連結して出力
でいいのでは?
No.1
- 回答日時:
それこそリストの中身をインデックス毎に分割してませんしね。
なのでそのようにリストの値が一回で書き出されるのでしょう。
import csv
csvlist = ["abc","def"]
f = open("output.csv", "w")
writecsv = csv.writer(f, lineterminator='\n')
for x in csvlist:writecsv.writerow(x) #ここでリストを要素毎に分割して書き込みをする。
f.close()
結果:
a,b,c
d,e,f
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
自作scratch アニメの商用利用
-
画像生成AIのプロンプトの作り...
-
pythonの実行に関する質問
-
vba クリップボードクリアにつ...
-
パイソンのソースコードをChatG...
-
数学、プログラミング、物理、...
-
pip --versionがエラーになる
-
OS入ってる機器のソフト・アプ...
-
Python... 環境設定 初心者です...
-
Python 3.12.2 か一番最新のパ...
-
CSVファイルの複数行削除
-
AIがプログラムする時代のプロ...
-
IT業で開発をされてる方々に質...
-
共テのプログラミング言語はPyt...
-
初心者powershellのPS1ファイル...
-
PowerAutomateで運賃検索がした...
-
AIのプログラムについて教えて...
-
プログラミングの進学について
-
過剰なオブジェクト指向脳から...
-
Google ColaboでGUI作成
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excelマクロ 空白セルを無視し...
-
VBAでcsvファイルもシートもあ...
-
ダブルコーテーション付きでCSV...
-
【ExcelVBA】300万件越えCSVか...
-
ファイル名を変数で書きこむfwr...
-
VBAで複数のCSVからレコードセ...
-
CSVで余計な空行が入る
-
複数のファイルをまたぐエクセ...
-
VB.netでShellExecuteがしたい
-
LibreOffice Calcのマクロで、...
-
【C#】 csvファイルをバイナリ...
-
pythonでリストをCSVに出力する...
-
EXCEL→CSV保存時のダブルクォー...
-
PYthon Django csv関連
-
pythonについて質問です。 csv...
-
マクロで使うfor文
-
プログラムの間違いについて
-
Pythonのコードエラーについて...
-
Rubyを使用してcsvファイルを処...
-
CSVデータの文字列置換
おすすめ情報
失礼しました。
下記修正させていただきます。
間違い:abc,def と A1, A2に配置されてしまいます。
正しい:abc,def と A1, B1に配置されてしまいます。
しかし、今回やりたいのは、
abc
def
とA1, A2することです。
めぐみん_ さん
ありがとうございます!
あと1つだけ質問させてください。
a,b,c
d,e,f
こちらを
abc
def
とする方法があったりしますかね・・・・?
カンマで1文字ずつ区切らず、かつ、改行させたく・・・
お手数をおかけしますがよろしくお願いいたします。