使用python写入m3u文件

2024-10-04 05:29:22 发布

您现在位置:Python中文网/ 问答频道 /正文

我做了这个脚本,我试图用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()

Tags: nameimportreidreadvalueresponselink
1条回答
网友
1楼 · 发布于 2024-10-04 05:29:22

您的数据写入代码几乎没有问题:

  1. 对于找到的每一个value项,在循环中打开文件
  2. 您只打开文件进行写入
  3. 在每次迭代中,您故意将内部filehandle位置更改为文件的开头,只读取整个文件和flush剩下的内容。这并不危险,只是没有必要。但您可能需要一些时间来回顾一下您对文件操作的了解。在
  4. 您使用with语句,它会自动关闭filehandle,但是仍然会调用close()

如果只打开一次文件进行写入,然后循环查看值列表,这并没有什么错:

with open('C:\\Users\\dir\\Desktop\\muhtesem_yuzyil_kosem.m3u', 'wb') as f:
       for name,link in value:
            f.write(name)
            f.write(link)

或者,您可以在每次迭代时打开文件,但请确保打开文件进行读写:

^{pr2}$

相关问题 更多 >