我一直在尝试根据 python 中的 url 获取网络广播电台的名称/标题,但到目前为止还没有运气。网络广播电台似乎使用 HTTP 之外的其他协议,但如果我错了,请纠正我。
例如:http://89.238.146.142:7030 http://89.238.146.142:7030
有标题:
“伊维萨全球广播电台”
我如何将此标题存储在变量中?任何帮助将不胜感激:)
亲切的问候,
弗里格
从一点点开始curl
,它似乎正在使用喊话 http://forums.radiotoolbox.com/viewtopic.php?t=74协议,因此您正在寻找以以下内容开头的早期行icy-name:
$ curl http://89.238.146.142:7030 | head -5
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
100 13191 0 13191 0 0 16013 0 --:--:-- --:--:-- --:--:-- 28516ICY 200 OK
icy-notice1:<BR>This stream requires <a href="http://www.winamp.com/">Winamp</a><BR>
icy-notice2:SHOUTcast Distributed Network Audio Server/Linux v1.9.8<BR>
icy-name:Ibiza Global Radio
icy-genre:Electronic
100 33463 0 33463 0 0 30954 0 --:--:-- 0:00:01 --:--:-- 46579
curl: (23) Failed writing body
$
所以:
>>> import urllib2
>>> f = urllib2.urlopen('http://89.238.146.142:7030')
>>> for i, line in enumerate(f):
... if line.startswith('icy-name') or i > 20: break
...
>>> if i > 20: print 'failed to find station name'
... else: print 'station name is', line.replace('icy-name:', '')
...
station name is Ibiza Global Radio
>>>
您可能想添加例如一些.lower()
调用,因为我相信这些标头名称不区分大小写,但这是一般的想法。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)