获取网页源码的小例子,代码很简单,就不多作解释了。

不过一定要注意网页的编码问题,否则会出现乱码的!!!

  1. #include <QtCore>
  2. #include <QtNetwork>
  3. //网页地址
  4. const QString URLSTR = "http://www.csdn.net/";
  5. //储存网页代码的文件
  6. const QString FILE_NAME = "code.html";
  7. int main(int argc, char **argv)
  8. {
  9. QCoreApplication app(argc, argv);
  10. QUrl url(URLSTR);
  11. QNetworkAccessManager manager;
  12. QEventLoop loop;
  13. QTextCodec *codec;
  14. QNetworkReply *reply;
  15. qDebug() << "Reading html code form " << URLSTR;
  16. reply = manager.get(QNetworkRequest(url));
  17. //请求结束并下载完成后,退出子事件循环
  18. QObject::connect(reply, SIGNAL(finished()), &loop, SLOT(quit()));
  19. //开启子事件循环
  20. loop.exec();
  21. //获取源码,打开文件
  22. QFile file(FILE_NAME);
  23. if( !file.open(QIODevice::WriteOnly | QIODevice::Text) )
  24. {
  25. qDebug() << "Cannot open the file: " << FILE_NAME;
  26. return 0;
  27. }
  28. QTextStream out(&file);
  29. QString codeContent = reply->readAll();
  30. //将获取到的网页源码写入文件
  31. //一定要注意编码问题,否则很容易出现乱码的
  32. codec = QTextCodec::codecForHtml(codeContent.toAscii());
  33. codeContent = codec->toUnicode(codeContent.toAscii());
  34. out.setCodec(codec);
  35. out << codeContent << endl;
  36. file.close();
  37. qDebug() << "Finished, the code have written to " << FILE_NAME;
  38. return 0;
  39. }

http://blog.csdn.net/small_qch/article/details/7200271

QT:轻松获取网页源码的更多相关文章

  1. Python: PySide(Qt)异步获取网页源码

    学习PyQt UI编程笔记.相对PyQt来说,PySide资料为少. 此篇记录异步获取代码后,同步显示于界面窗体中,涉及线程网步,此为知识点. 直录代码: # encoding: utf-8 from ...

  2. C语言之socket获取网页源码

    写爬虫也许你用的是python,类似urlopen(url).read()即可获得普通的网页的源码,或者用的java的网络库加上流操作,或者其他高级语言.但你有没有想过使用C语言来实现呢?我曾经以为用 ...

  3. Python爬虫学习之获取网页源码

    偶然的机会,在知乎上看到一个有关爬虫的话题<利用爬虫技术能做到哪些很酷很有趣很有用的事情?>,因为强烈的好奇心和觉得会写爬虫是一件高大上的事情,所以就对爬虫产生了兴趣. 关于网络爬虫的定义 ...

  4. vc++获取网页源码

    1. 获取网页源码的步骤: com组件的初始化 创建WinHttpRequest对象 创建并实例化WinHttpRequest组件 调用Open方法打开连接 调用Send方法发送请求 使用Respon ...

  5. vc++获取网页源码之使用import+接口方式

    1.使用IWinHttpRequest获取网页源码 首先要创建基于对话框的mfc应用程序 2.import+接口方式 首先导入winhttp.dll,使用IWinHttpRequest接口 #impo ...

  6. 高效获取网页源码COM

    目前获取网页源码有几种方法: 1.WebClient下载页面2.HttpWebRequest发请求获取3.com组件xmlhttp获取 三者比较:WebClient代码最少,效率最慢:xmlhttp代 ...

  7. Python3 Selenium WebDriver网页的前进、后退、刷新、最大化、获取窗口位置、设置窗口大小、获取页面title、获取网页源码、获取Url等基本操作

    Python3 Selenium WebDriver网页的前进.后退.刷新.最大化.获取窗口位置.设置窗口大小.获取页面title.获取网页源码.获取Url等基本操作 通过selenium webdr ...

  8. Python3.x获取网页源码

    Python3.x获取网页源码 1,获取网页的头部信息以确定网页的编码方式: import urllib.request res = urllib.request.urlopen('http://ww ...

  9. c# HttpClient获取网页源码

    #region 获取网页源码 public static string HttpClientGetHtmls(string url) { try { var client = new HttpClie ...

随机推荐

  1. C++----练习--string 从文件中一个一个单词的读直到文件尾

    从文件中读取单词.并每行显示一个: 1. #include<iostream> #include<string> #include<vector> int main ...

  2. curl fake ip

    curl --header "X-Forwarded-For: 219.137.148.2" "http://www.x.com"

  3. Effective Java2读书笔记-创建和销毁对象(一)

    第1条:考虑用静态工厂方法代替构造器 通常情况下,我们创建一个对象采取new的形式,但是还有一种方法也是经常使用到的,它的名称叫做静态工厂方法. 例如,java中基本类型boolean的包装类Bool ...

  4. C语言IO操作总结

    C语言IO操作总结C程序将输入看做字节流,流的来源是文件.输入设备.或者另一程序的输入:C程序将输出也看做字节流:流的目的是文件.视频显示等: 文件处理:1 :fopen("filename ...

  5. 纯CSS实现三列DIV等高布局

    <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> &l ...

  6. winform datagridview 添加行号。

    private void dataGridView_RowPostPaint(object sender, DataGridViewRowPostPaintEventArgs e) { private ...

  7. mysql 保留的关键字

    mysql> select precision from Product; ERROR 1064 (42000): You have an error in your SQL syntax; c ...

  8. css案例学习之div ul li a 实现导航效果

    效果 代码 <html> <head> <title>无需表格的菜单</title> <style> body{ background-co ...

  9. Contains Duplicate II 解答

    Question Given an array of integers and an integer k, find out whether there are two distinct indice ...

  10. HTML5 Canvas Arc Tutorial

    HTML5 Canvas Arc Tutorial HTML5 Canvas Arc Tutorial