0

Web ページのソースから画像の URL を取得する方法を見つけようとしています。Web ページのソースを文字列に取得し、それを 1 行ずつ解析して、URL のある行を見つけることができます。ただし、行から URL だけを取得する良い方法を見つけることができませんでした。これは QRegExp で実行できると思いますが、使用方法がわかりません。

解析しようとしている行

<img width="980" height="1515" id="mainImg" src="//test/123.jpg" alt="test">

最終作業コード

void MainWindow::on_btnDownload_clicked()
{
QString url = "http://test.foo.com";

QUrl qURL = url;

QNetworkAccessManager manager;
QNetworkReply *response = manager.get(QNetworkRequest(QUrl(url)));
QEventLoop event;
connect(response,SIGNAL(finished()),&event,SLOT(quit()));
event.exec();
QString html = response->readAll();
QStringList str;
str = html.split("\n");
//qDebug() << url;

for (int i = 0; i < str.size(); ++i){
    if(str.at(i).contains("id=\"mainImg\"", Qt::CaseInsensitive)){
        QString pic;
        pic = str.at(i);
        pic = pic.remove(QRegExp("<img[^>]*src=['|\"]",  Qt::CaseInsensitive));
        pic = pic.remove(QString::fromStdString("//"), Qt::CaseInsensitive);
        pic = pic.remove('"');
        pic = pic.remove("'");
        pic = pic.remove('<');
        pic = pic.remove('>');
        pic = pic.remove(';');
        pic = pic.left(pic.length()-1);
        //qDebug() << str.at(i);
        qDebug() << pic;
    }
}


qDebug() << "Lines: " << str.size();
}
4

0 に答える 0