我做了这个脚本,我试图用regex写我请求的东西,当它写到一个文件时,'w'
只写我最后一个尝试的条目('w'
,'wb'
,'w+'
)它们全都写了我做错的最后一个条目?在
#-*- coding: utf-8 -*-
import urllib2,urllib
import re
import os
import sys
value=[]
url='https://www.youtube.com/feeds/videos.xmlchannel_id=UCHXdylbsyDVN4UO2Fv8Cgm&API'
req = urllib2.Request(url)
req.add_header('User-Agent', 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_2) AppleWebKit/537.75.14 (KHTML,like Gecko) Version/7.0.3 Safari/573.75.14')
response = urllib2.urlopen(req)
link=response.read()
response.close()
match=re.compile('<entry>\n <id>.+?</id>\n <yt:videoId>(.+?)</yt:videoId>\n <yt:channelId>.+?</yt:channelId>\n <title>(.*?)\(HD\)</title>').findall(link)
for videoid,isim in match:
#print videoid,isim
name='#EXTINF:-1 ,'+isim+'\n'
link='plugin://plugin.video.youtube/play/?video_id='+videoid+'\n'
value.append((str(name), str(link)))
for name,link in value:
#print name,link
with open('C:\\Users\\dir\\Desktop\\muhtesem_yuzyil_kosem.m3u', 'wb+') as f:
f.write(name)
f.write(link)
f.seek(0) # Important: return to the top of the file before reading, otherwise you'll just read an empty string
data = f.read() # Returns 'somedata\n'
f.flush()
f.close()
您的数据写入代码几乎没有问题:
value
项,在循环中打开文件flush
剩下的内容。这并不危险,只是没有必要。但您可能需要一些时间来回顾一下您对文件操作的了解。在with
语句,它会自动关闭filehandle,但是仍然会调用close()
如果只打开一次文件进行写入,然后循环查看值列表,这并没有什么错:
或者,您可以在每次迭代时打开文件,但请确保打开文件进行读写:
^{pr2}$相关问题 更多 >
编程相关推荐