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

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

ただいまの
回答率

90.76%

  • HTML

    8319questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • Swift

    6700questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

  • Xcode

    3850questions

    Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

  • MacOS(OSX)

    1787questions

    MacOSとは、Appleの開発していたGUI(グラフィカルユーザーインターフェース)を採用したオペレーションシステム(OS)です。Macintoshと共に、市場に出てGUIの普及に大きく貢献しました。

Onoを使ってHTMLを解析して動画や画像を表示したい。

受付中

回答 0

投稿

  • 評価
  • クリップ 1
  • VIEW 112

maikeru--

score 23

まずこちらの記事を読んで欲しいです!
https://qiita.com/syamaoka/items/49d2750cc2d6599fbfa0
こちらの記事で説明されていることとと同様のことをやろうと思い試してみたのですが、動画の表示や画像の表示はどのようにすればいいのか分からず質問してしまいました。以下のコードでhtmlを解析しているのですが、動画は<p><iframe ...></p>という構造になっており、以下のコードからpタグは取り出せるのですが、

element.stringValue


で<iframe...>は消えてしまい取り出すことができません。どうすれば<ifram ...>をString型で取り出すことができるでしょうか? elementの型がONOXMLElementなのもネックです。
よろしくお願いします。 

import UIKit
import Ono

class HTMLParser: NSObject {
    var elements = [Element]()

    func HTMLDocumentWithString(htmlText:String) -> [Element] {
        do {
            let document = try ONOXMLDocument.htmlDocument(with: htmlText, encoding: String.Encoding.utf8.rawValue, error: nil)
            // htmlの子要素を参照
            for bodyElement in document.rootElement.children {
                let bodyElement = bodyElement
                // bodyの子要素を参照
                for element in bodyElement.children {
                    if let element = element as? ONOXMLElement {
                        print(element)
                        // 許可しているタグのみパースする
                        if let tag = PermitTag(rawValue: element.tag) {
                            parseElement(element: element, tag: tag)
                        }
                    }
                }
            }
        } catch {
            print("error when parser html")
        }
        return elements
    }

    private func parseElement(element: ONOXMLElement, tag: PermitTag) {
        switch tag {
        case .p:
            elements.append(Element(tag: tag, value: (element.stringValue?.trimmingCharacters(in: NSCharacterSet.whitespacesAndNewlines))!))
        case .h2:
            elements.append(Element(tag: tag, value: (element.stringValue?.trimmingCharacters(in: NSCharacterSet.whitespacesAndNewlines))!))
        default:
            break
        }
    }
}
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

まだ回答がついていません

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

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

関連した質問

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

  • HTML

    8319questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • Swift

    6700questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

  • Xcode

    3850questions

    Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

  • MacOS(OSX)

    1787questions

    MacOSとは、Appleの開発していたGUI(グラフィカルユーザーインターフェース)を採用したオペレーションシステム(OS)です。Macintoshと共に、市場に出てGUIの普及に大きく貢献しました。