Google Chart API:XYLine图渲染问题

0 投票
1 回答
819 浏览
提问于 2025-04-16 04:56

我正在尝试使用不太好文档化的 GChartWrapper 库,通过 Google Chart API 创建一个 XYLine 图表。

这是我用来生成图表的一部分代码:

data = []
traffic_max = 0
date_minmax = []

#I have a number of timestamped readings in two series
for site in sites:
  site_data = get_datapoints_for(site)

  date_values = [datetime_to_unix(item.timestamp) for item in site_data]
  date_minmax = minmax(date_minmax + date_values) #get min and max values for
                                                  #scaling
  traffic_values = [item.traffic for item in site_data]
  traffic_max = max(traffic_max, *traffic_values) #just get maximum for readings

  #build graph
  data.append(date_values)
  data.append(traffic_values)

#add leeway to axes
date_minmax[0] -= 500
date_minmax[1] += 500
traffic_max /= 0.9

#build graph
chart = LineXY(data)
chart.legend(*sites)
chart.color("green", "red")
chart.size(600,400)
chart.scale(date_minmax[0], date_minmax[1], 0, traffic_max)
chart.axes.type("xy")
chart.axes.range(0, *date_minmax)
chart.axes.range(1, 0, traffic_max)

chart_url = chart.url

但是,我得到的是这个:

link text

问题是:红色的那条线怎么了?


为了方便你,这里是经过格式化的 data

[[1286116241.448437, 1286118544.4077079, 1286119431.18503, 1286121011.5838161],
 [6710.9899999999998,
  6716.2799999999997,
  6641.8900000000003,
  6644.9499999999998],
 [1286116241.979831,
  1286118545.0123601,
  1286119431.9650409,
  1286121012.1839011],
 [38323.860000000001,
  38326.620000000003,
  38327.660000000003,
  38329.610000000001]]

这是经过格式化的包装器生成的参数列表:

chco=008000,FF0000
chd=t:1286116241.0,1286118544.0,1286119431.0,1286121011.0
    6711.0,6716.3,6641.9,6644.9
    1286116241.0,1286118545.0,1286119431.0,1286121012.0
    38323.9,38326.6,38327.7,38329.6
chdl=gaming.stackexchange.com
    serverfault.com
chds=1286115741.0,1286121512.0,0,42588.4555556
chs=600x400
cht=lxy
chxr=0,1286115741.0,1286121512.0
    1,0,42588.4555556
chxt=x,y
cht=lxy
chxr=0,1286116241.45,1286121012.18
    1,0,42588.4555556
chxt=x,y

1 个回答

0

问题出在这里:

chart.scale(date_minmax[0], date_minmax[1], 0, traffic_max)

谷歌的API让你可以为每一组数据设置不同的比例。因此,你需要为每一组数据指定比例,而上面的代码只影响了第一组数据。

把那行代码改成:

chart.scale(*[date_minmax[0], date_minmax[1], 0, traffic_max]*len(sites))

...就会让所有的数据组都使用相同的比例。

撰写回答