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

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

ただいまの
回答率

87.96%

Swift RSS pubDate("Wed, 04 Nov 2019 15:02:11 +0000")を取得し("2019-11-4")のように変換してtableViewCellに反映したい

受付中

回答 1

投稿

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

score 20

ブログをまとめたRSSリーダーのiOSアプリを作っています。
tableViewCellの"title"には記事タイトルを、"subTitle"には更新日を記載したいです。
現在、XMLパーサーを使って記事タイトル・更新日を取得できているのですが、更新日のフォーマットが"Wed, 04 Nov 2019 15:02:11 +0000"のようになっています。これを"2019-11-4"や"11月4日(水)"のように変換しようと方法を検索して、以下のようなコードを見つけました。

 // string = "Wed, 04 Nov 2015 15:02:11 +0000"
        let identifier = NSLocale.current.identifier
        if identifier == "ja_JP" {
            let dateFormatter = DateFormatter()
            // 書式が変わらない固定ロケールで一度値を取得
            dateFormatter.locale = NSLocale(localeIdentifier: "en_US_POSIX") as Locale
            dateFormatter.dateFormat = "EEE, dd MMM yyyy HH:mm:ss ZZZZ"
            let r_date = dateFormatter.date(from: "")

            if let d = r_date {
                 // ロケールを日本語にして曜日を取得
                dateFormatter.locale = NSLocale(localeIdentifier: "ja_JP") as Locale
                dateFormatter.dateFormat = "MM月dd日(E)"
                tmpEntry.add(dateFormatter.string(from: d))
            }
        }


参考記事

しかしこのコードをどこに記載すれば目的が達成できるのか分からず困っています。
以下ソースコード

import UIKit

class ListViewController1: UITableViewController, XMLParserDelegate {

    var parser:XMLParser!
    var items = [Item]()
    var item:Item?
    var currentString = ""
    var tmpEntry : NSMutableArray!

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
            return items.count
    }

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath)
        cell.textLabel?.text = items[indexPath.row].title
        cell.detailTextLabel?.text = items[indexPath.row].date
        //ラベルの表示行数を無制限にする
        cell.textLabel?.numberOfLines = 0
        return cell
    }

    func numberOfSectionsInTableView(tableView: UITableView) -> Int {
        return 2
    }

    override func viewDidLoad() {
        //テーブルの高さを自動で調節
        self.tableView.rowHeight = UITableView.automaticDimension    
    }
    override func viewDidAppear(_ animated: Bool) {
        super.viewDidAppear(animated)
        startDownload()
    }

    func startDownload() {
        self.items = []
        if let url = URL(string: "https://www.ryukke.com/?feed=rss2") {
                if let parser = XMLParser(contentsOf: url) {
                self.parser = parser
                self.parser.delegate = self
                self.parser.parse()
            }
        }
    }

    func parser(_ parser: XMLParser, didStartElement elementName: String, namespaceURI: String?, qualifiedName qName: String?, attributes attributeDict: [String : String]) {
        self.currentString = ""
        if elementName == "item" {
            self.item = Item()
        }

    }

    func parser(_ parser: XMLParser, foundCharacters string: String) {
        self.currentString += string
    }

    func parser(_ parser: XMLParser, didEndElement elementName: String, namespaceURI: String?, qualifiedName qName: String?) {
        switch elementName {
        case "title": self.item?.title = currentString
        case "link": self.item?.link = currentString
        case "pubDate": self.item?.date = currentString
        case "item": self.items.append(self.item!)
        default : break
        }
    }

    func parserDidEndDocument(_ parser: XMLParser) {
        self.tableView.reloadData()
    }

    override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
        if let indexPath = self.tableView.indexPathForSelectedRow {
            let item = items[indexPath.row]
            let controller = segue.destination as! DetailViewController
            controller.title = item.title
            controller.link = item.link
        }
    }
}
import Foundation

class Item {
    var title = ""
    var link = ""
    var date = ""
    }


投げっぱなしな質問になってしまって申し訳ありません。よろしくお願い致します。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

+1

ItemのdateをStringからDate型に変更して、
self.item?.date = currentString のところでcurrentStringではなくcurrentStringをもとに生成したDateにするとよいと思います

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/11/20 08:11

    回答ありがとうございます!
    勉強不足で申し訳ないのですが、currentStringをもとに生成したDateにするとは、具体的にどうすれば良いのでしょうか?

    キャンセル

  • 2019/11/20 22:35

    dateFormatter.date(from: currentString) でDate型のインスタンスを生成できるのはわかりますか?

    キャンセル

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

  • ただいまの回答率 87.96%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

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

  • トップ
  • XMLに関する質問
  • Swift RSS pubDate("Wed, 04 Nov 2019 15:02:11 +0000")を取得し("2019-11-4")のように変換してtableViewCellに反映したい