KL
Konstantin Lazarev20 декабря 2016 г. 21:37

Запрос позиций сайта в выдаче Google при помощи Qt

Qt, Google

Добрый день. Как при помощи Qt узнать позицию сайта в Google по запросу?
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

7
Evgenii Legotckoi
  • 21 декабря 2016 г. 13:41

День добрый.
Вопрос так вопрос… Смотря что Вы хотите получить..
Если хотите просматривать данные по своему сайту, то у Google Search Console и Google Analytics есть API.
Изучаете API и реализовываете запросы с помощью QNetworkAccessManager.

Если хотите искать инфу в поисковике по любому сайту, то можете посмотреть информацию по XML Custom Search API.

А как такового открытого API для проверок позиций сайта Google вроде бы не предоставляет… Иначе бы у всех этих сервисов проверки позиций сайта результаты были бы одинаковые.

То есть необходимо реализовывать систему запросов и обработки поисковой выдачи. Это немаленькая задача, но вполне реализуемая средствами Qt. Только не забывайте, что Google не приемлет автоматизированных средств запросов к поиску и довольно быстро попросит ввести каптчу.

    KL
    • 21 декабря 2016 г. 23:26
    При помощи парсинга выдачи Google возможно реализовать? Я могу спарсить html код страницы сайтов, которые не защищены.
    В Google стоит защита. Может, у вас есть подобная практика?
      Evgenii Legotckoi
      • 21 декабря 2016 г. 23:35
      Нет. Такой практики у меня нет.
      Но думаю, что при парсинге XML выдачи для кастомизированного поиска может что-нибудь получиться.
      Посмотрите описание XML API Reference
        KL
        • 22 декабря 2016 г. 14:56
        • Ответ был помечен как решение.

        Евгений, большое спасибо. Ваша статья очень мне помогла, как и урок, который вы написали для работы с QNetworkAccessManager. Я не совсем понял зачем создавать отдельный класс downloade, почему нельзя создать все в widget. Но запрос составил и файл скачал. Запрос выглядит примерно так:
        QUrl url(“http://www.google.ru/search?hl=ru&q=платные+комментарии&oq=платные+комментарии&lr=lang_ru&cr=countryRU&xml_no_dtd;”); // URL, к которому будем получать данные

        Подскажите, при считывании из файла идет наложение текста выглядит это примерно так:

          Evgenii Legotckoi
          • 23 декабря 2016 г. 11:43

          Пожалуйста.
          Есть интерфейс, а есть логика работы с сетью… На мой взгляд логику работы с сетью лучше выносить в отдельный класс. Хотя вы правы, можно было сделать всё в widget`е.

          Видимо, в наложении текста должна была быть картинка. Прикрепите её во вложения.

            KL
            • 25 декабря 2016 г. 1:58

            Евгений, подскажите как загрузить массив фотографий при помощи QNetworkAccessManager.
            Вот моя реализация.
            GoogleQuery::GoogleQuery(QWidget *parent) :
            QWidget(parent),
            ui(new Ui::GoogleQuery)
            {
            ui->setupUi(this);
            connect(&pageYandexTic,SIGNAL(finished(QNetworkReply*)), SLOT(on_load(QNetworkReply*)));
            QStringList list;
            QStringList.append(UrlSite1);
            QStringList.append(UrlSite2);
            QStringList.append(UrlSite3);
            }
            void GoogleQuery::on_pushButton_clicked()
            {
            for(int i=0; i<list.size(); i++)
            {
            QNetworkRequest request;
            request.setUrl(list);
            pageYandexTic.get(request); // QNetworkAccessManager отправляем запрос с урлом картинки
            }
            }
            void GoogleQuery::on_load(QNetworkReply* reply)
            {
            QPixmap pixmap;
            pixmap.loadFromData(reply->readAll());
            ui->label->setPixmap(pixmap);
            }

            Проблема в том, что изначально выполняется цикл for, а затем on_load. Картинки не успевают загрузиться.

              Evgenii Legotckoi
              • 26 декабря 2016 г. 14:21

              Вам нужно запускать скачивание следующей картинки только тогда, когда скачалась предыдущая, а не сразу запихивать все запросы в кучку.
              Правильная реализация будет такая.

              #ifndef MAINWINDOW_H
              #define MAINWINDOW_H
               
              #include <QMainWindow>
              #include <QNetworkAccessManager>
              #include <QNetworkReply>
              #include <QNetworkRequest>
              #include <QLabel>
               
              namespace Ui {
              class MainWindow;
              }
               
              class MainWindow : public QMainWindow
              {
                  Q_OBJECT
               
              public:
                  explicit MainWindow(QWidget *parent = 0);
                  ~MainWindow();
               
              private slots:
                  void on_pushButton_clicked();
                  void onLoad(QNetworkReply* reply);
               
              private:
                  Ui::MainWindow *ui;
                  QStringList urlsList;
                  QNetworkAccessManager downloader;
              };
               
              #endif // MAINWINDOW_H
              #include "mainwindow.h"
              #include "ui_mainwindow.h"
               
              MainWindow::MainWindow(QWidget *parent) :
                  QMainWindow(parent),
                  ui(new Ui::MainWindow)
              {
                  ui->setupUi(this);
                  connect(&downloader, &QNetworkAccessManager::finished, this, &MainWindow::onLoad);
               
                  urlsList.append("https://www.alfaromeousa.com/content/alfausa/en/cars/alfa-romeo-giulia-quadrifoglio/_jcr_content/image.img.png/1461766810123.png");
                  urlsList.append("https://www.alfaromeousa.com/content/alfausa/en/cars/alfa-romeo-4c-spider/_jcr_content/image.img.png/1461766874697.png");
                  urlsList.append("http://buyersguide.caranddriver.com/media/assets/submodel/7063.jpg");
              }
               
              MainWindow::~MainWindow()
              {
                  delete ui;
              }
               
              void MainWindow::on_pushButton_clicked()
              {
                  if (!urlsList.isEmpty())
                  {
                      QNetworkRequest request;
                      request.setUrl(urlsList.first());
                      urlsList.removeFirst();
                      downloader.get(request);
                  }
              }
               
              void MainWindow::onLoad(QNetworkReply *reply)
              {
                  QPixmap image;
                  image.loadFromData(reply->readAll());
                  QLabel* label = new QLabel(this);
                  label->setPixmap(image);
                  ui->verticalLayout->addWidget(label);
                  on_pushButton_clicked();
              }

               

                Комментарии

                Только авторизованные пользователи могут публиковать комментарии.
                Пожалуйста, авторизуйтесь или зарегистрируйтесь
                Ua

                Qt - Тест 001. Сигналы и слоты

                • Результат:84баллов,
                • Очки рейтинга4
                Ua

                Qt - Тест 001. Сигналы и слоты

                • Результат:42баллов,
                • Очки рейтинга-8
                ОК

                Qt - Тест 001. Сигналы и слоты

                • Результат:47баллов,
                • Очки рейтинга-6
                Последние комментарии
                ИМ
                Игорь Максимов22 ноября 2024 г. 21:51
                Django - Урок 017. Кастомизированная страница авторизации на Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                Evgenii Legotckoi
                Evgenii Legotckoi31 октября 2024 г. 23:37
                Django - Урок 064. Как написать расширение для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                A
                ALO1ZE19 октября 2024 г. 17:19
                Читалка fb3-файлов на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                ИМ
                Игорь Максимов5 октября 2024 г. 16:51
                Django - Урок 064. Как написать расширение для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                d
                dblas55 июля 2024 г. 20:02
                QML - Урок 016. База данных SQLite и работа с ней в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                Сейчас обсуждают на форуме
                f
                firstlunoxod15 февраля 2025 г. 13:46
                Рисование на QGraphicsScene при зажатой кнопке мыши Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
                Дмитрий
                Дмитрий3 февраля 2025 г. 16:24
                Создание deb-пакета. Как создать ярлык на рабочем столе после установки собственного deb-пакета? Всем привет. Сделал свой deb-пакет с программой. Всё устанавливается и работает. Ставлю по пути /usr/bin/my_application. Как для пользователя при установке пакета сразу создать ярлык на раб…
                NW
                Nayo Wai30 января 2025 г. 19:22
                не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
                n
                nkly3 января 2025 г. 12:52
                Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
                M
                Marsel17 августа 2023 г. 0:26
                OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.

                Следите за нами в социальных сетях