首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > perl python >

帮小弟我看下小弟我这个脚本为什么不能创建文件

2013-07-16 
大虾帮我看下我这个脚本为什么不能创建文件?本帖最后由 evandpr 于 2013-07-11 20:44:54 编辑import urlli

大虾帮我看下我这个脚本为什么不能创建文件?
本帖最后由 evandpr 于 2013-07-11 20:44:54 编辑

import urllib.request
import re,os
a = urllib.request.urlopen('http://www.daomubiji.com').read().decode('utf-8')
urls=re.findall('<a.*?href=(.*?\.html.*?)<\/a>',a,re.I)
for i in urls:
    url = i.split('"')[1]
    fname = url.split('/')[3]
    #print(str(fname))
    b = urllib.request.urlopen(url).read()
    f = open(str(fname), 'w')
    f.write(str(b))
    f.close()



注释掉PRINT可以正常输出文件名,但是创建文件的时候,报错:" ioerror:[error 2] no such file or directory '' "


[解决办法]
试了一下,循环中的第一次fname输出来的是空字符'',以后能正常输出,改了一句代码你试试看?
import urllib.request
import re,os
a = urllib.request.urlopen('http://www.daomubiji.com').read().decode('utf-8')
urls=re.findall('<a.*?href=(.*?\.html.*?)<\/a>',a,re.I)

for i in urls:
    url = i.split('"')[1]
    if url.split('/')[3]=='':
        fname = url.split('/')[2]
    else:
        fname = url.split('/')[3]
    #fname = url.split('/')[3]
    #print(str(fname))
    b = urllib.request.urlopen(url).read()
    f = open(str(fname), 'w')
    f.write(str(b))
    f.close()

热点排行