asp 采集程序常用函数分析

来源:asp之家 时间:2011-03-16 11:03:00 

原理
采集程序实际上是通过了XML中的XMLHTTP组件调用其它网站上的网页。比如新闻采集程序,很多都是调用了sina的新闻网页,并且对其中的html进行了一些替换,同时对广告也进行了过滤。用采集程序的优点有:无须维护网站,因为采集程序中的数据来自其他网站,它将随着该网站的更新而更新;可以节省服务器资源,一般采集程序就几个文件,所有网页内容都是来自其他网站。缺点有:不稳定,如果目标网站出错,程序也会出错,而且,如果目标网站进行升级维护,那么采集程序也要进行相应修改;速度,因为是远程调用,速度和在本地服务器上读取数据比起来,肯定要慢一些。

一、事例
下面就XMLHTTP在ASP中的应用做个简单说明

代码如下:


<%
'常用函数
'1、输入url目标网页地址,返回值getHTTPPage是目标网页的html代码

function getHTTPPage(url) 
dim Http 
set Http=server.createobject("MSXML2.XMLHTTP") 
Http.open "GET",url,false 
Http.send() 
if Http.readystate<>4 then 
exit function 
end if 
getHTTPPage=bytesToBstr(Http.responseBody,"GB2312") 
set http=nothing 
if err.number<>0 then err.Clear 
end function '2、转换乱玛,直接用xmlhttp调用有中文字符的网页得到的将是乱玛,可以通过adodb.stream组件进行转换

Function BytesToBstr(body) 
dim objstream 
set objstream = Server.CreateObject("adodb.stream") 
objstream.Type = 1 
objstream.Mode =3 
objstream.Open 
objstream.Write body 
objstream.Position = 0 
objstream.Type = 2 
objstream.Charset = "GB2312" '转换原来默认的UTF-8编码转换成GB2312编码,否则直接用XMLHTTP组件调用有中文字符的网页得到的将是乱码 
BytesToBstr = objstream.ReadText 
objstream.Close 
set objstream = nothing 
End Function 
Dim Url,Html 
Url=http://www.cidianwang.com; 
Html = getHTTPPage(Url) 
Response.write Html 
%> 

二、几个常用的函数
(一)InStr 函数
描述
返回某字符(string2)串在另一字符串(string1)中第一次出现的位置。
语法
InStr(string1, string2)
例如:

Dim SearchString, SearchChar 
SearchString ="http://www.cidianwang.com" ' 要在其中搜索的字符串。 
SearchChar = "jb51" ' 搜索 "jb51"。 
MyBK = Instr(SearchString, SearchChar) ' 返回 8 
'如果找不到则返回“0”,例如: 
SearchChar = "BK" 
MyBK = Instr(SearchString, SearchChar) ' 返回 0 (二)Mid 函数
描述
从字符串中返回指定数目的字符。
语法
Mid(string, start, over)
例如:
Dim MyBK
MyBK = Mid("我们的BK(www.google)设计", 7, 12) '截取字符串"我们的BK(www.google)设计"第7个字符以后的12个字符
'此时MyBK的值就变成了"www.google"
(三)Replace 函数
Dim SearchString, SearchChar
SearchString ="我们的BK设计是一个网站建设资源网站" ' 要在其中搜索的字符串。
SearchString =Replace(SearchString,"BK设计","Www.google")
'此时SearchString的值就变成了"我们的Www.google是一个网站建设资源网站"

标签:asp,采集程序
0
投稿

猜你喜欢

  • 关于Python内存分配时的小秘密分享

    2023-10-07 15:26:16
  • python对html过滤处理的方法

    2023-04-25 15:28:57
  • 浅析Python的命名空间与作用域

    2022-11-27 04:19:04
  • FileSystem对象常用的文件操作函数有哪些?

    2009-11-01 15:11:00
  • HTML5的革新:结构之美

    2011-04-16 10:57:00
  • 对python中的控制条件、循环和跳出详解

    2022-03-08 00:41:44
  • SQL 查询性能优化 解决书签查找

    2024-01-28 08:33:53
  • Python利用scikit-learn实现近邻算法分类的示例详解

    2021-01-09 18:43:44
  • 支持png透明图片的php生成缩略图类分享

    2023-11-18 07:26:13
  • MySQL更新存放JSON的字段、\\“ 转义成 “的问题描述

    2024-01-13 16:30:00
  • Pandas中DataFrame常用操作指南

    2023-08-31 14:14:41
  • SQL SERVER数据库表记录只保留N天图文教程

    2024-01-29 06:34:21
  • python爬取m3u8连接的视频

    2023-06-18 13:40:21
  • 关于python中密码加盐的学习体会小结

    2022-05-13 09:47:04
  • pandas 透视表中文字段排序方法

    2023-11-13 19:11:22
  • textarea 在IE和FF下换行无法正常显示的解决方法

    2022-09-11 01:33:40
  • python Jupyter运行时间实例过程解析

    2022-04-15 04:38:21
  • python调用摄像头的示例代码

    2021-10-11 02:18:09
  • 详解python中递归函数

    2022-04-17 19:40:55
  • Pyqt5 实现窗口缩放,控件在窗口内自动伸缩的操作

    2022-10-16 06:32:09
  • asp之家 网络编程 m.aspxhome.com