我一直在尝试根据 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/

10-10 16:53