1

我正在进行抓取,我需要提取网站的信息,基本上它是提供指向内页的链接

这是我的小尝试,我可以得到州的名称,但我承认我现在需要更深入,我不擅长正则表达式

请指导。这是我的代码

<cfscript>
function stripHTML(str) {
    str = reReplaceNoCase(str, "<*style.*?>(.*?)</style>","","all");
    str = reReplaceNoCase(str, "<*script.*?>(.*?)</script>","","all");
    str = reReplaceNoCase(str, "<.*?>","","all");
    str = reReplaceNoCase(str, "^.*?>","");
    str = reReplaceNoCase(str, "<.*$","");
    return trim(str);
}
</cfscript>
<cfset start = false>
<cfhttp url="http://www.mapsofindia.com/pincode/" method="get"></cfhttp>
<cfset status = cfhttp.Statuscode>
<cfif status IS '200 OK'>
    <cfset start = true>
</cfif>
<cfif start>
    <cfset string = cfhttp.filecontent />
    <cfset StartText = '<table cellpadding=4 cellspacing=0 align="center" border="0" class=extrtable width="90%">' />
    <cfset Start = FindNoCase(StartText, string, 1) />
    <cfset EndText='<td style="width:50%">&nbsp;</td></tr></table><br /><br />' />
    <cfset Length=Len(StartText) />
    <cfset End = FindNoCase(EndText, string, Start) />
    <cfset parse = Mid(string, Start+Length, End-Start-Length) />
    <cfset parse = Insert('+',parse,FindNoCase("</a>", parse))>
    <cfset parse = trim(parse) />
    <cfset dbData = stripHTML(ListQualify(parse,'+'))>
    <cfloop list="#createLst#" index="k" delimiters="+">
        <cfquery name="insert_data" datasource="#request.dsn#">
        INSERT INTO cw_states(state,countrycode,country) 
        VALUES('#k#','IN','India')
        </cfquery>
    </cfloop>
    <table align="center">
        <cfoutput>#parse#<br></cfoutput>
    </tr>
    </table>
</cfif>

这是正确列出页面上的cfoutput,但我无法插入数据库。

问题 #2:链接指向另一个列出该州城市的页面,我想附加我的页面,如 index2.cfm?url=#link# 它将提取城市并将城市插入我的城市表中在链接上它应该像 index3.cfm?url=#link# 这将打开另一个 zip 页面并将这些 zip 名称插入数据库中

请指导

4

0 回答 0