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

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

ただいまの
回答率

90.47%

  • Python

    8571questions

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

pythonの出力の形式について教えていただきたいです。

解決済

回答 4

投稿

  • 評価
  • クリップ 0
  • VIEW 254

rainrain

score 16

python初心者です。
現在numpyでcsvファイルを読み込んで、欲しい範囲のデータだけを出力するプログラムを作っています。
プログラム自体はやって欲しい動作をしてくれるのですが、出力が以下のようになっています(数字は適当です)。この配列?のような形式の出力をどうにかしたいです。

[1  3]
[2  4]
[3  5]

・ 

☝のままでは使いづらいので、再び以下のようにcsv形式で出力させたいのですが可能でしょうか?

1,3
2,4
3,5

 簡単にプログラムの説明

data = np.loadtxt(・・・)   #ここでcsvを読み込み

・  (範囲を指定する処理)

for ・・・    #以下三行の処理を繰り返し
a = int(a)+1    #出力したい行番号
result = data[a]  ☜ ここが問題だと思われる
print(result)

ちなみに(余裕があれば教えていただきたい)

現在は端末に表示させているのですが、ファイルに直接結果を落とす方法も教えていただけると非常に助かります。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 4

checkベストアンサー

+1

for ・・・    #以下三行の処理を繰り返し
    a = int(a)+1    #出力したい行番号
    result = data[a] # ☜ ここが問題だと思われる
    print(result)

あまりこういう処理はおすすめできませんが(前の質問にスライスを使う方法の回答つけたんですが・・・)、まあこれで動いちゃってるなら仕方ないでしょう。

for ・・・ 
    a = int(a)+1 
    result = data[a] 
    print(*result, sep=',') # LouiS0616さんの回答の方法

ファイル出力したい場合は、まずコマンドラインでリダイレクトするという方法があります(pythonというよりシェルの機能ですが)。こんな感じで実行すると標準出力をファイルに吐き出せます。

$ python filename > out.csv

python側でやるなら、こんな感じで。

f = open("out.csv", "w")
for ・・・ 
    a = int(a)+1 
    result = data[a] 
    print(*result, sep=',', file=f) 
f.close()

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/06/20 13:40 編集

    色々ありがとうございます!
    ファイルへのはき出しも上手くいきました!
    ただ、ファイルへはき出したときに、改行されず横並びにくっついて表示されてしまうので、上手く改行する方法があれば教えていただきたいです。
    たびたび申し訳ございません。
    よろしくお願いいたします。

    キャンセル

  • 2018/06/20 14:10

    試しにexcelで開いてみると、上手く改行されていました!
    初心者丸出しの質問ばかりしてしまい申し訳ありませんでした。

    キャンセル

  • 2018/06/20 15:41

    メモ帳とかで見たときに横並びになっちゃうのは改行文字の問題だと思うので、
    print(*result, sep=',', end="\r\n", file=f)
    とかで解消すると思います(デフォルトは"\n"ですがLFとしてみなされるのでしょう。\r\nでCRLFになります)

    キャンセル

+1

将来的に『ファイルに直接結果を落とす』のでしたら、
numpy.savetxtでcsvを出力し、そのファイルを読んだ方が早いのでは?


強引にやるなら、こんな感じ。

result = np.array([1, 2, 3])
print(*result, sep=', ')

追記

欲しい範囲のデータだけを出力する

ひょっとして、『実行時に指定した』範囲のデータを出力するってことです?

import numpy as np

data = np.loadtxt('file.csv', delimiter=',')
while True:
    row_num = int(input())
    if 0 <= row_num < data.shape[0]:
        print(*data[row_num], sep=', ')
    elif row_num == -1:
        break

入力

1
0
2
-1

出力

4.0, 5.0, 6.0
1.0, 2.0, 3.0
7.0, 8.0, 9.0

PaizaIO

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

どちらも素直に解釈していいのか迷いますが......

#convert csv-format.
string = str(list).replace('[','').replace(']','').replace(' ',',')
#processor write result.
f = open('test.txt','w')

f.write(string)

f.close()

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

pandasをオススメしておきます。

import pandas as pd
df = pd.read_csv('path.csv')
df.head(10).to_csv('path_head.csv')

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

関連した質問

同じタグがついた質問を見る

  • Python

    8571questions

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