mirror of https://github.com/Kozea/pygal.git
Jason R. Coombs
14 years ago
1 changed files with 150 additions and 127 deletions
@ -1,133 +1,156 @@ |
|||||||
import sys, os |
import sys, os |
||||||
from svg.charts.plot import Plot |
|
||||||
g = Plot({ |
|
||||||
'min_x_value': 0, |
|
||||||
'min_y_value': 0, |
|
||||||
'area_fill': True, |
|
||||||
'stagger_x_labels': True, |
|
||||||
'stagger_y_labels': True, |
|
||||||
'show_x_guidelines': True |
|
||||||
}) |
|
||||||
g.add_data({'data': [1, 25, 2, 30, 3, 45], 'title': 'series 1'}) |
|
||||||
g.add_data({'data': [1,30, 2, 31, 3, 40], 'title': 'series 2'}) |
|
||||||
g.add_data({'data': [.5,35, 1, 20, 3, 10.5], 'title': 'series 3'}) |
|
||||||
res = g.burn() |
|
||||||
f = open(r'Plot.py.svg', 'w') |
|
||||||
f.write(res) |
|
||||||
f.close() |
|
||||||
|
|
||||||
from svg.charts import time_series |
|
||||||
|
|
||||||
g = time_series.Plot({}) |
|
||||||
|
|
||||||
g.timescale_divisions = '4 hours' |
|
||||||
g.stagger_x_labels = True |
|
||||||
g.x_label_format = '%d-%b %H:%M' |
|
||||||
#g.max_y_value = 200 |
|
||||||
|
|
||||||
g.add_data({'data': ['2005-12-21T00:00:00', 20, '2005-12-22T00:00:00', 21], 'title': 'series 1'}) |
|
||||||
|
|
||||||
res = g.burn() |
|
||||||
|
|
||||||
f = open(r'TimeSeries.py.svg', 'w') |
|
||||||
f.write(res) |
|
||||||
f.close() |
|
||||||
|
|
||||||
|
from svg.charts.plot import Plot |
||||||
from svg.charts import bar |
from svg.charts import bar |
||||||
|
from svg.charts import time_series |
||||||
fields = ['Internet', 'TV', 'Newspaper', 'Magazine', 'Radio'] |
|
||||||
|
|
||||||
g = bar.VerticalBar(fields) |
|
||||||
|
|
||||||
g.stack = 'side' |
|
||||||
g.scale_integers = True |
|
||||||
g.width, g.height = 640,480 |
|
||||||
g.graph_title = 'Question 7' |
|
||||||
g.show_graph_title = True |
|
||||||
|
|
||||||
g.add_data({'data': [-2, 3, 1, 3, 1], 'title': 'Female'}) |
|
||||||
g.add_data({'data': [0, 2, 1, 5, 4], 'title': 'Male'}) |
|
||||||
|
|
||||||
open(r'VerticalBar.py.svg', 'w').write(g.burn()) |
|
||||||
|
|
||||||
g = bar.HorizontalBar(fields) |
|
||||||
|
|
||||||
g.stack = 'side' |
|
||||||
g.scale_integers = True |
|
||||||
g.width, g.height = 640,480 |
|
||||||
g.graph_title = 'Question 7' |
|
||||||
g.show_graph_title = True |
|
||||||
|
|
||||||
g.add_data({'data': [-2, 3, 1, 3, 1], 'title': 'Female'}) |
|
||||||
g.add_data({'data': [0, 2, 1, 5, 4], 'title': 'Male'}) |
|
||||||
|
|
||||||
open(r'HorizontalBar.py.svg', 'w').write(g.burn()) |
|
||||||
|
|
||||||
g = bar.VerticalBar(fields) |
|
||||||
options = dict( |
|
||||||
scale_integers=True, |
|
||||||
stack='side', |
|
||||||
width=640, |
|
||||||
height=480, |
|
||||||
graph_title='Question 8', |
|
||||||
show_graph_title=True, |
|
||||||
no_css=False,) |
|
||||||
g.__dict__.update(options) |
|
||||||
|
|
||||||
g.add_data(dict(data=[2,22,98,143,82], title='intermediate')) |
|
||||||
g.add_data(dict(data=[2,26,106,193,105], title='old')) |
|
||||||
open('VerticalBarLarge.py.svg', 'w').write(g.burn()) |
|
||||||
|
|
||||||
from svg.charts import pie |
from svg.charts import pie |
||||||
g = pie.Pie({}) |
|
||||||
options = dict( |
|
||||||
width=640, |
|
||||||
height=480, |
|
||||||
fields=fields, |
|
||||||
graph_title='Question 7', |
|
||||||
expand_greatest = True, |
|
||||||
show_data_labels = True, |
|
||||||
) |
|
||||||
g.__dict__.update(options) |
|
||||||
g.add_data({'data': [-2, 3, 1, 3, 1], 'title': 'Female'}) |
|
||||||
g.add_data({'data': [0, 2, 1, 5, 4], 'title': 'Male'}) |
|
||||||
|
|
||||||
open('Pie.py.svg', 'w').write(g.burn()) |
|
||||||
|
|
||||||
from svg.charts import schedule |
from svg.charts import schedule |
||||||
|
|
||||||
title = "Billy's Schedule" |
def sample_Plot(): |
||||||
data1 = [ |
g = Plot({ |
||||||
"History 107", "5/19/04", "6/30/04", |
'min_x_value': 0, |
||||||
"Algebra 011", "6/2/04", "8/11/04", |
'min_y_value': 0, |
||||||
"Psychology 101", "6/28/04", "8/9/04", |
'area_fill': True, |
||||||
"Acting 105", "7/7/04", "8/16/04" |
'stagger_x_labels': True, |
||||||
] |
'stagger_y_labels': True, |
||||||
|
'show_x_guidelines': True |
||||||
g = schedule.Schedule(dict( |
}) |
||||||
width = 640, |
g.add_data({'data': [1, 25, 2, 30, 3, 45], 'title': 'series 1'}) |
||||||
height = 480, |
g.add_data({'data': [1,30, 2, 31, 3, 40], 'title': 'series 2'}) |
||||||
graph_title = title, |
g.add_data({'data': [.5,35, 1, 20, 3, 10.5], 'title': 'series 3'}) |
||||||
show_graph_title = True, |
return g |
||||||
key = False, |
|
||||||
scale_x_integers = True, |
def sample_TimeSeries(): |
||||||
scale_y_integers = True, |
g = time_series.Plot({}) |
||||||
show_data_labels = True, |
|
||||||
show_y_guidelines = False, |
g.timescale_divisions = '4 hours' |
||||||
show_x_guidelines = True, |
g.stagger_x_labels = True |
||||||
# show_x_title = True, # not yet implemented |
g.x_label_format = '%d-%b %H:%M' |
||||||
x_title = "Time", |
#g.max_y_value = 200 |
||||||
show_y_title = False, |
|
||||||
rotate_x_labels = True, |
g.add_data({'data': ['2005-12-21T00:00:00', 20, '2005-12-22T00:00:00', 21], 'title': 'series 1'}) |
||||||
rotate_y_labels = False, |
|
||||||
x_label_format = "%m/%d", |
return g |
||||||
timescale_divisions = "1 week", |
|
||||||
add_popups = True, |
def generate_samples(): |
||||||
popup_format = "%m/%d/%y", |
yield 'Plot', sample_Plot() |
||||||
area_fill = True, |
yield 'TimeSeries', sample_TimeSeries() |
||||||
min_y_value = 0, |
yield 'VerticalBar', SampleBar.vertical() |
||||||
)) |
yield 'HorizontalBar', SampleBar.horizontal() |
||||||
|
yield 'VerticalBarLarge', SampleBar.vertical_large() |
||||||
g.add_data(dict(data=data1, title="Data")) |
yield 'Pie', sample_Pie() |
||||||
|
|
||||||
f = open('Schedule.py.svg', 'w').write(g.burn()) |
|
||||||
|
class SampleBar: |
||||||
|
fields = ['Internet', 'TV', 'Newspaper', 'Magazine', 'Radio'] |
||||||
|
|
||||||
|
@classmethod |
||||||
|
def vertical(cls): |
||||||
|
|
||||||
|
g = bar.VerticalBar(cls.fields) |
||||||
|
|
||||||
|
g.stack = 'side' |
||||||
|
g.scale_integers = True |
||||||
|
g.width, g.height = 640,480 |
||||||
|
g.graph_title = 'Question 7' |
||||||
|
g.show_graph_title = True |
||||||
|
|
||||||
|
g.add_data({'data': [-2, 3, 1, 3, 1], 'title': 'Female'}) |
||||||
|
g.add_data({'data': [0, 2, 1, 5, 4], 'title': 'Male'}) |
||||||
|
|
||||||
|
return g |
||||||
|
|
||||||
|
@classmethod |
||||||
|
def horizontal(cls): |
||||||
|
g = bar.HorizontalBar(cls.fields) |
||||||
|
|
||||||
|
g.stack = 'side' |
||||||
|
g.scale_integers = True |
||||||
|
g.width, g.height = 640,480 |
||||||
|
g.graph_title = 'Question 7' |
||||||
|
g.show_graph_title = True |
||||||
|
|
||||||
|
g.add_data({'data': [-2, 3, 1, 3, 1], 'title': 'Female'}) |
||||||
|
g.add_data({'data': [0, 2, 1, 5, 4], 'title': 'Male'}) |
||||||
|
|
||||||
|
return g |
||||||
|
|
||||||
|
@classmethod |
||||||
|
def vertical_large(cls): |
||||||
|
g = bar.VerticalBar(cls.fields) |
||||||
|
options = dict( |
||||||
|
scale_integers=True, |
||||||
|
stack='side', |
||||||
|
width=640, |
||||||
|
height=480, |
||||||
|
graph_title='Question 8', |
||||||
|
show_graph_title=True, |
||||||
|
no_css=False,) |
||||||
|
g.__dict__.update(options) |
||||||
|
|
||||||
|
g.add_data(dict(data=[2,22,98,143,82], title='intermediate')) |
||||||
|
g.add_data(dict(data=[2,26,106,193,105], title='old')) |
||||||
|
return g |
||||||
|
|
||||||
|
def sample_Pie(): |
||||||
|
g = pie.Pie({}) |
||||||
|
options = dict( |
||||||
|
width=640, |
||||||
|
height=480, |
||||||
|
fields=SampleBar.fields, |
||||||
|
graph_title='Question 7', |
||||||
|
expand_greatest = True, |
||||||
|
show_data_labels = True, |
||||||
|
) |
||||||
|
g.__dict__.update(options) |
||||||
|
g.add_data({'data': [-2, 3, 1, 3, 1], 'title': 'Female'}) |
||||||
|
g.add_data({'data': [0, 2, 1, 5, 4], 'title': 'Male'}) |
||||||
|
return g |
||||||
|
|
||||||
|
def sample_Schedule(): |
||||||
|
title = "Billy's Schedule" |
||||||
|
data1 = [ |
||||||
|
"History 107", "5/19/04", "6/30/04", |
||||||
|
"Algebra 011", "6/2/04", "8/11/04", |
||||||
|
"Psychology 101", "6/28/04", "8/9/04", |
||||||
|
"Acting 105", "7/7/04", "8/16/04" |
||||||
|
] |
||||||
|
|
||||||
|
g = schedule.Schedule(dict( |
||||||
|
width = 640, |
||||||
|
height = 480, |
||||||
|
graph_title = title, |
||||||
|
show_graph_title = True, |
||||||
|
key = False, |
||||||
|
scale_x_integers = True, |
||||||
|
scale_y_integers = True, |
||||||
|
show_data_labels = True, |
||||||
|
show_y_guidelines = False, |
||||||
|
show_x_guidelines = True, |
||||||
|
# show_x_title = True, # not yet implemented |
||||||
|
x_title = "Time", |
||||||
|
show_y_title = False, |
||||||
|
rotate_x_labels = True, |
||||||
|
rotate_y_labels = False, |
||||||
|
x_label_format = "%m/%d", |
||||||
|
timescale_divisions = "1 week", |
||||||
|
add_popups = True, |
||||||
|
popup_format = "%m/%d/%y", |
||||||
|
area_fill = True, |
||||||
|
min_y_value = 0, |
||||||
|
)) |
||||||
|
|
||||||
|
g.add_data(dict(data=data1, title="Data")) |
||||||
|
|
||||||
|
return g |
||||||
|
|
||||||
|
def save_samples(): |
||||||
|
root = os.path.dirname(__file__) |
||||||
|
for sample_name, sample in generate_samples(): |
||||||
|
res = sample.burn() |
||||||
|
with open(os.path.join(root, sample_name+'.py.svg'), 'w') as f: |
||||||
|
f.write(res) |
||||||
|
|
||||||
|
if __name__ == '__main__': |
||||||
|
save_samples() |
||||||
|
|
||||||
|
Loading…
Reference in new issue