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

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

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

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

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

Q&A

解決済

2回答

6353閲覧

Python; csvデータ書き出しで、データのかたまり毎に空白行を挿入したい

Reikirin

総合スコア23

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

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

0グッド

0クリップ

投稿2020/02/04 13:14

前提・実現したいこと

9000個の数値データが縦に連続で並べられたCSVファイル(=file1.csv)に対して、
90個のデータごとに一行空白を作り、他に2つの変数を用意し、(変数1,変数2,file1[])のように並べたいです。
但しfile1.csvは以下のように与えられているとします。
1,35
2,22
3,10
4,30
.
.
.

Pythonで、

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

以下は空白行を入れずに並べたコードです。ここまでは問題なくできました。
ここからどうすれば90個のデータごとに空白行を挿入できるかがわかりません。。。

from csv import writer import pandas as pd df = pd.read_csv('file1.csv', names=['num1', 'num2']) i = 1 data = [] for v in range(0,100): if i <= 100: for f in range(90 * (i-1), 90 * i): data.append((v, f - 90 * (i-1), df.iloc[f,1])) else: break i+=1 with open('file2.csv', 'w', newline = '') as f: Wr = writer(f) for d in data: Wr.writerow(d)

試したこと

newlineを部分的に入れない方法で行けるかな?と試してみましたが、同じ結果になってしまいました。

from csv import writer import pandas as pd df = pd.read_csv('file1.csv', names=['num1', 'num2']) i = 1 data = [] for v in range(0,100): if i <= 100: for f in range(90 * (i-1), 90 * i): data.append((v, f - 90 * (i-1), df.iloc[f,1])) else: break i+=1 for x in data: if x[2] == 89: with open('file2.csv', 'w') as f: Wr = writer(f) for d in data: Wr.writerow(d) else: with open('file2.csv', 'w', newline = '') as f: Wr = writer(f) for d in data: Wr.writerow(d)

補足情報(FW/ツールのバージョンなど)

python.3以上使用

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

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

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

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

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

guest

回答2

0

ベストアンサー

90行ごとに追記モードでデータを書き出すと行うと良いのではないでしょうか

Python

1import pandas as pd 2import numpy as np 3 4df = pd.read_csv('file1.csv', names=['num1', 'num2']) 5 6for i in range(0, len(df), 90): 7 # 90行だけデータを書き込む 8 if i == 0: 9 df.iloc[i:i+90].to_csv('out.csv') 10 else: 11 # 2回目以降は追記モードで書き込み(ヘッダもいらない) 12 df.iloc[i:i+90].to_csv('out.csv', mode='a', header=None) 13 14 # なんか書き込む 15 with open('out.csv', 'a') as f: 16 f.write('\n') 17 f.write('Hello!!\n')

投稿2020/02/05 00:12

magichan

総合スコア15898

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

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

Reikirin

2020/02/05 06:20

回答ありがとうございます。 すみません質問なんですが、最後の書き込む部分だけもう少し詳しく教えていただけませんでしょうか。
magichan

2020/02/05 06:34

for文中の前半で CSVファイルから90行ずつ書き込みを行い、後半部で90行の次の行に”何か”を書き込んでいるだけです。 今回のソースの場合は 90行のデータの次の行に 空行('\n') Hello World\n の2行を追記しております。 この "Hello World\n" を書き込んでいる部分を自分の書き込みたい内容に合わせて書き直して頂くとよいのではないでしょうか
Reikirin

2020/02/05 07:09

ありがとうございます。よくわかりました。 素早い対応に感謝いたします。
Reikirin

2020/02/05 07:10

望みの操作ができました。
guest

0

linuxのコマンドであれば以下のようにしてできますよ。v1、v2は変数1、変数2です。

linux

1sed s/^/v1,v2,/ file1.csv | awk '{print $0 ((NR%90)?"":"\n")}'

投稿2020/02/04 13:41

ikapy

総合スコア1167

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

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

Reikirin

2020/02/05 06:22

回答ありがとうございます。なるほど、linuxだとそうなるんですね。 現在、Windowsを使用しているので、ちょっと使えるかわかりませんが、参考にしてみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問