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

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

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

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

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

1027閲覧

Railsアプリから出力するcsvファイル内の日時データの出力表示を変更したい

GenkiSugiyama

総合スコア86

CSV

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

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2020/08/05 10:09

あるアプリの管理者側機能を作成しています。

登録ユーザー一覧画面でユーザー情報のcsv出力機能を実装している中で気になる点があったので質問させていただきます。

表題の通りrailsでcsv出力機能を作っているのですが、created_atカラムなどの表示をフル表示から日付のみに変更したいと考えています。

【現在のcsvファイル】
イメージ説明

上の画像で「2020-07-15 17:35:50 +0900」となっている部分を「2020-07-15」のみにしたいです。

下記のコードでcsv出力を実現しています。

【app/models/user.rb】

class User < ApplicationRecord ・ ・ def self.csv_attributes #出力するカラムを指定 ["name", "tel", "email", "post_code", "prefectures", "address_1", "address_2", "room_number", "created_at", "updated_at"] end def self.generate_csv csv_columns = ["名前", "電話番号", "メールアドレス", "郵便番号", "都道府県", "住所1", "住所2", "住所3", "登録日時", "最終更新日時"] CSV.generate(headers: true) do |csv| csv << csv_columns all.each do |user| csv << csv_attributes.map{ |attr| user.send(attr) } end end end ・ ・ end

【app/controllers/users_controller】

def index @users = User.all.order("created_at DESC").page(params[:page]) respond_to do |format| format.html format.csv { send_data @users.generate_csv, filename: "users-#{Time.zone.now.strftime("%Y%m%d%S")}.csv" } end end

app/views/users/index.html内に出力ボタンを配置して、それをクリックするとcsvデータが出力される仕組みになっています。

user.rbのself.generate_csv内でcsvファイルにレコードのデータを渡すときに何かしらの処理を行えばいいのかなと考えているのですが
具体的な案がわからない状態です。

よろしくお願いいたします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

私がよくやるのは modelに
def created_at_date created_at.strftime('%Y/%m/%d') end
として、
["name", "tel", "email", "post_code", "prefectures", "address_1", "address_2", "room_number", "created_at", "updated_at"]
の created_at を created_at_date にする

投稿2020/08/05 10:48

winterboum

総合スコア23324

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

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

GenkiSugiyama

2020/08/07 06:05

毎度ご回答ありがとうございます! ご提示いただいたコードで期待通りの出力ができました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問