我一直在尝试根据 python 中的 url 获取互联网广播电台的名称/标题,但到目前为止还没有运气。网络广播电台似乎使用另一种协议(protocol)而不是 HTTP,但如果我错了,请纠正我。
例如:
http://89.238.146.142:7030
有标题:
“伊维萨全局广播电台”
如何将此标题存储在变量中?任何帮助将不胜感激:)
亲切的问候,
弗里格
最佳答案
从一点点 curl
来看,它似乎正在使用 shoutcast 协议(protocol),因此您正在寻找以 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()
调用,因为我相信这些 header 名称是不区分大小写的,但这是总体思路。关于Python:从 url 获取shoutcast/互联网广播电台的名称,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/3110494/