Python语言技术文档

微信小程序技术文档

php语言技术文档

jsp语言技术文档

asp语言技术文档

C#/.NET语言技术文档

html5/css技术文档

javascript

点击排行

您现在的位置:首页 > 技术文档 > asp函数/类库

MusicGet_类

来源:中文源码网    浏览:231 次    日期:2024-04-27 07:40:14
【下载文档:  MusicGet_类.txt 】


MusicGet 类
复制代码 代码如下:<% Response.Expires = 0 Response.expiresabsolute = Now() - 1 Response.addHeader "pragma", "no-cache" Response.addHeader "cache-control", "private" Response.CacheControl = "no-cache" Response.Buffer = True Response.Clear Server.ScriptTimeOut=999999999 '*************************************************************** '* 定义 MusicGet 类 '*************************************************************** Class GetHttp Private OXML,FSO,ADOS Private Sub Class_Initialize Set OXML = server.CreateObject("Microsoft.XMLHTTP") Set FSO = Server.CreateObject("Scripting.FileSystemObject") Set ADOS = Server.CreateObject("ADODB.Stream") End Sub Private Sub Class_Terminate Set OXML = Nothing Set FSO = Nothing Set ADOS = Nothing End Sub Public Property Get Version Version="动感采集系统v3.0" End Property '***************************************************************** ' function(私有) ' 作用 :利用流进行中文编码 ' 参数 :vIn(要进行编码的字符患) '***************************************************************** Private Function BytesToBstr(body) Dim Bdat Bdat=Body ADOS.Type = 1 ADOS.Mode =3 ADOS.Open ADOS.Write Bdat ADOS.Position = 0 ADOS.Type = 2 ADOS.Charset = "GB2312" BytesToBstr = ADOS.ReadText ADOS.Close End Function '***************************************************************** ' function(私有) ' 作用 :利用流保存文件 ' 参数 :from(远程文件地址),tofile(保存文件位置) '***************************************************************** Private Function SaveFiles(byref from,byref tofile) Dim Datas Datas=GetData(from,0) Response.Write "保存成功:"&formatnumber(len(Datas)/1024*2,2)&"Kb" response.Flush if formatnumber(len(Datas)/1024*2,2)>1 then ADOS.Type = 1 ADOS.Mode =3 ADOS.Open ADOS.write Datas ADOS.SaveToFile server.mappath(tofile),2 ADOS.Close() else Response.Write "保存失败:文件大小"&formatnumber(len(imgs)/1024*2,2)&"Kb,小于1K" response.Flush end if end function '***************************************************************** ' function(私有) ' 作用 :利用fso检测文件是否存在,存在返回true,不存在返回false ' 参数 :filespes(文件位置) '***************************************************************** Private Function IsExists(byref filespec) If (FSO.FileExists(server.MapPath(filespec))) Then IsExists = True Else IsExists = False End If End Function '***************************************************************** ' function(私有) ' 作用 :利用fso检测文件夹是否存在,存在返回true,不存在返回false ' 参数 :folder(文件夹位置) '***************************************************************** Private Function IsFolder(byref Folder) If FSO.FolderExists(server.MapPath(Folder)) Then IsFolder = True Else IsFolder = False End If End Function '***************************************************************** ' function(私有) ' 作用 :利用fso创建文件夹 ' 参数 :fldr(文件夹位置) '***************************************************************** Private Function CreateFolder(byref fldr) Dim f Set f = FSO.CreateFolder(Server.MapPath(fldr)) CreateFolder = f.Path Set f=nothing End Function '***************************************************************** ' function(公有) ' 作用 :保存文件,并自动创建多级文件夹 ' 参数 :fromurl(远程文件地址),tofiles (保存位置) '***************************************************************** Public Function SaveData(byref FromUrl,byref ToFiles) ToFiles=trim(Replace(ToFiles,"//","/")) flName=ToFiles fldr="" If IsExists(flName)=false then GetNewsFold=split(flName,"/") For i=0 to Ubound(GetNewsFold)-1 if fldr="" then fldr=GetNewsFold(i) else fldr=fldr&"\"&GetNewsFold(i) end if If IsFolder(fldr)=false then CreateFolder fldr End if Next SaveFiles FromUrl,flName End if End function '***************************************************************** ' function(公有) ' 作用 :取得远程数据 ' 参数 :url(远程文件地址),getmode (模式:0为二进制,1为中文编码) '***************************************************************** Public Function GetData(byref url,byref GetMode) 'on error resume next SourceCode = OXML.open ("GET",url,false) OXML.send() if OXML.readystate<>4 then exit function if GetMode=0 then GetData = OXML.responseBody else GetData = BytesToBstr(OXML.responseBody) end if if err.number<>0 then err.Clear End Function '***************************************************************** ' function(公有) ' 作用 :格式化远程图片地址为本地位置 ' 参数 :imgurl(远程图片地址),imgfolder (本地图片目录),fristname(加入的前缀名称) '***************************************************************** Public Function FormatImgPath(byref ImgUrl,byref ImgFolder,byref FristName,byref noimg) strpath="" ImgUrl=ImgUrl if instr(ImgUrl,"Nophoto") or lenb(GetData(ImgUrl,0))<=0 then strpath=noimg Response.Write ""&strpath&"" &vbcrlf else if Instr(ImgUrl,".asp") then strpath=FristName&"_"&Mid(ImgUrl, InStrRev(ImgUrl, "=")+1)&".jpg" else strpath=FristName&"_"&Mid(ImgUrl, InStrRev(ImgUrl, "/")+1) end if strpath = ImgFolder&"/"&strpath strpath = Replace(strpath,"//","/") if left(strpath,1)="/" then strpath=right(strpath,len(strpath)-1) strpath = trim(strpath) Response.Write ""&strpath&"" &vbcrlf savedata ImgUrl,strpath end if FormatImgPath = strpath End function '***************************************************************** ' function(公有) ' 作用 :格式化远程音乐文件地址为本地位置 ' 参数 :MusicUrl(远程文件地址),oServerUrl (原服务连接地址),MusicFolder(本地音乐文件目录) '***************************************************************** Public Function FormatMusicPath(byref MusicUrl,byref oServerUrl,byref MusicFolder) strpath="" strpath = Replace(MusicUrl,oServerUrl,"") strpath = MusicFolder&"/"&strpath strpath = Replace(strpath,"//","/") if left(strpath,1)="/" then strpath=right(strpath,len(strpath)-1) FormatMusicPath=trim(strpath) End function '***************************************************************** ' function(公有) ' 作用 :格式化html '***************************************************************** Public Function FormatHtml(Str,itype) if itype=0 then Str=replace(Str,chr(39),"'") Str=replace(Str,chr(34),""") Str=replace(Str,"<","<") Str=replace(Str,">",">") else Str=replace(Str,"chr(39)","") Str=replace(Str,"chr(34)","") end if FormatHtml=Str End function '***************************************************************** ' function(公有) ' 作用 :截取字符 ' 参数 :str要操作的对像,start开始字符,last结束字符,n模式 '***************************************************************** Public Function GetContent(byref str,byref start,byref last,byref n) If Instr(lcase(str),lcase(start))>0 then select case n case 0 '左右都截取(都取前面)(去处关键字) GetContent=Right(str,Len(str)-Instr(lcase(str),lcase(start))-Len(start)+1) GetContent=Left(GetContent,Instr(lcase(GetContent),lcase(last))-1) case 1 '左右都截取(都取前面)(保留关键字) GetContent=Right(str,Len(str)-Instr(lcase(str),lcase(start))+1) GetContent=Left(GetContent,Instr(lcase(GetContent),lcase(last))+Len(last)-1) case 2 '只往右截取(取前面的)(去除关键字) GetContent=Right(str,Len(str)-Instr(lcase(str),lcase(start))-Len(start)+1) case 3 '只往右截取(取前面的)(包含关键字) GetContent=Right(str,Len(str)-Instr(lcase(str),lcase(start))+1) case 4 '只往左截取(取后面的)(包含关键字) GetContent=Left(str,InstrRev(lcase(str),lcase(start))+Len(start)-1) case 5 '只往左截取(取后面的)(去除关键字) GetContent=Left(str,InstrRev(lcase(str),lcase(start))-1) case 6 '只往左截取(取前面的)(包含关键字) GetContent=Left(str,Instr(lcase(str),lcase(start))+Len(start)-1) case 7 '只往右截取(取后面的)(包含关键字) GetContent=Right(str,Len(str)-InstrRev(lcase(str),lcase(start))+1) case 8 '只往左截取(取前面的)(去除关键字) GetContent=Left(str,Instr(lcase(str),lcase(start))-1) case 9 '只往右截取(取后面的)(包含关键字) GetContent=Right(str,Len(str)-InstrRev(lcase(str),lcase(start))) end select Else GetContent="" End if End function '***************************************************************** ' function(公有) ' 作用 :取得字符的拼音 '***************************************************************** Public Function GetPyChar(byref Char) tmp=65536+asc(Char) if(tmp>=45217 and tmp<=45252) or (tmp=65601) or (tmp=65633) or (tmp=37083) then GetPyChar= "A" elseif(tmp>=45253 and tmp<=45760) or (tmp=65602) or (tmp=65634) or (tmp=39658) then GetPyChar= "B" elseif(tmp>=45761 and tmp<=46317) or (tmp=65603) or (tmp=65635) or (tmp=33405) then GetPyChar= "C" elseif(tmp>=46318 and tmp<=46930) or (tmp>=61884 and tmp<=61884) or (tmp=65604) or (tmp>=36820 and tmp<=38524) or (tmp=65636) then GetPyChar= "D" elseif(tmp>=46931 and tmp<=47009) or (tmp=65605) or (tmp=65637) or (tmp=61513) then GetPyChar= "E" elseif(tmp>=47010 and tmp<=47296) or (tmp=65606) or (tmp=65638) or (tmp=61320) or (tmp=63568) or (tmp=36281) then GetPyChar= "F" elseif(tmp>=47297 and tmp<=47613) or (tmp=65607) or (tmp=65639) or (tmp=35949) or (tmp=36089) or (tmp=36694) or (tmp=34808) then GetPyChar= "G" elseif(tmp>=47614 and tmp<=48118) or (tmp>=59112 and tmp<=59112) or (tmp=65608) or (tmp=65640) then GetPyChar= "H" elseif(tmp=65641) or (tmp=65609) or (tmp=65641) then GetPyChar="I" elseif(tmp>=48119 and tmp<=49061 and tmp<>48739) or (tmp>=62430 and tmp<=62430) or (tmp=65610) or (tmp=65642) or (tmp=39048) then GetPyChar= "J" elseif(tmp>=49062 and tmp<=49323) or (tmp=65611) or (tmp=65643) then GetPyChar= "K" elseif(tmp>=49324 and tmp<=49895) or (tmp>=58838 and tmp<=58838) or (tmp=65612) or (tmp=65644) or (tmp=62418) or (tmp=48739) then GetPyChar= "L" elseif(tmp>=49896 and tmp<=50370) or (tmp=65613) or (tmp=65645) then GetPyChar= "M" elseif(tmp>=50371 and tmp<=50613) or (tmp=65614) or (tmp=65646) then GetPyChar= "N" elseif(tmp>=50614 and tmp<=50621) or (tmp=65615) or (tmp=65647) then GetPyChar= "O" elseif(tmp>=50622 and tmp<=50905) or (tmp=65616) or (tmp=65648) then GetPyChar= "P" elseif(tmp>=50906 and tmp<=51386) or (tmp>=62659 and tmp<=63172) or (tmp=65617) or (tmp=65649) then GetPyChar= "Q" elseif(tmp>=51387 and tmp<=51445) or (tmp=65618) or (tmp=65650) then GetPyChar= "R" elseif(tmp>=51446 and tmp<=52217) or (tmp=65619) or (tmp=65651) or (tmp=34009) then GetPyChar= "S" elseif(tmp>=52218 and tmp<=52697) or (tmp=65620) or (tmp=65652) then GetPyChar= "T" elseif(tmp=65621) or (tmp=65653) then GetPyChar="U" elseif(tmp=65622) or (tmp=65654) then GetPyChar="V" elseif(tmp>=52698 and tmp<=52979) or (tmp=65623) or (tmp=65655) then GetPyChar= "W" elseif(tmp>=52980 and tmp<=53688) or (tmp=65624) or (tmp=65656) then GetPyChar= "X" elseif(tmp>=53689 and tmp<=54480) or (tmp=65625) or (tmp=65657) then GetPyChar= "Y" elseif(tmp>=54481 and tmp<=62383 and tmp<>59112 and tmp<>58838) or (tmp=65626) or (tmp=65658) or (tmp=38395) or (tmp=39783) then GetPyChar= "Z" elseif(tmp=65584) then GetPyChar="0-9" elseif(tmp=65585) then GetPyChar="0-9" elseif(tmp=65586) then GetPyChar="0-9" elseif(tmp=65587) then GetPyChar="0-9" elseif(tmp=65588) then GetPyChar="0-9" elseif(tmp=65589) then GetPyChar="0-9" elseif(tmp=65590) then GetPyChar="0-9" elseif(tmp=65591) then GetPyChar="0-9" elseif(tmp=65592) then GetPyChar="0-9" elseif(tmp=65593) then GetPyChar="0-9" else GetPyChar="0-9" end if end function '***************************************************************** ' function(公有) ' 作用 :循环取得字符串的拼音 '***************************************************************** Public Function GetPy(byref Str) for i=1 to len(Str) GetPy=GetPy&GetPyChar(mid(Str,i,1)) next end function '***************************************************************** ' function(公有) ' 作用 :取得歌曲歌词 '***************************************************************** Public Function LrcMusicGc(MusicName,singer) musicGc=Getdata("http://mp3.baidu.com/m?tn=baidump3lyric&ct=150994944&word="&musicname&"%20"&singer,1) if instr(musicgc,"建议您检查输入文字有无错误") then MusicGc= "暂无" else musicGc=FormatHtml(musicgc,0) musicGc=GetContent(musicgc,"专辑:",0) musicgc=Replace(musicgc,"<","<") musicgc=Replace(musicgc,">",">") musicgc=Replace(musicgc," "," ") musicgc=Replace(musicgc,"","") musicgc=Replace(musicgc,"","") musicgc=GetContent(musicgc,"

","

",0) 'response.write musicGc end if if musicgc="" then LrcMusicgc="暂无" else LrcMusicgc=MusicGc end if End function End Class %>

相关内容