
すいません質問があります。
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ランキング
-
プログラム言語
-
vba 正規表現について教えてく...
-
vba クリップボードクリアにつ...
-
pythonでのローカルファイルか...
-
if関数とは?
-
今のプログラミング言語
-
ネットワークフォルダの中身を...
-
プログラミングについて
-
画像生成AIのプロンプトの作り...
-
⚠️至急です!⚠️ Yahoo!知恵袋の...
-
自作scratch アニメの商用利用
-
プログラミング言語のバージョ...
-
uwscでPauseキーが押されたら、...
-
Python... 環境設定 初心者です...
-
Geminiフォーム 画像生成で 人...
-
数学、プログラミング、物理、...
-
pip --versionがエラーになる
-
pythonの実行に関する質問
-
OS入ってる機器のソフト・アプ...
-
CSVファイルの複数行削除
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBAでcsvファイルもシートもあ...
-
ダブルコーテーション付きでCSV...
-
【ExcelVBA】300万件越えCSVか...
-
Excelマクロ 空白セルを無視し...
-
LibreOffice Calcのマクロで、...
-
ファイル名を変数で書きこむfwr...
-
シート内容の文字列を置換してV...
-
EXCEL→CSV保存時のダブルクォー...
-
バッチファイルでcsvファイルに...
-
VBAで文字列を引数とするアドイ...
-
VBScript等で、CSV内の各文字列...
-
pythonによるcsv出力がうまくい...
-
VB.netでShellExecuteがしたい
-
IPアドレスのゼロパディング
-
CSVファイルの比較と結果の取得...
-
パイソン文法で ファイルオープ...
-
fortranでデータの抜き出しをし...
-
pythonのこのエラーがわかりません
-
pythonでリストをCSVに出力する...
-
FileListBoxで出すものを絞り込...
おすすめ情報
失礼しました。
下記修正させていただきます。
間違い:abc,def と A1, A2に配置されてしまいます。
正しい:abc,def と A1, B1に配置されてしまいます。
しかし、今回やりたいのは、
abc
def
とA1, A2することです。
めぐみん_ さん
ありがとうございます!
あと1つだけ質問させてください。
a,b,c
d,e,f
こちらを
abc
def
とする方法があったりしますかね・・・・?
カンマで1文字ずつ区切らず、かつ、改行させたく・・・
お手数をおかけしますがよろしくお願いいたします。