Highcharts:如何创建年龄组、性别、访问量的细分饼图?
Highcharts: How to create a drilldown pie of agegroup, gender, visits?
是否可以为以年龄组、性别和访问量作为数据的 csv 数据集创建带有高图的向下钻取饼图?
我一直试图那样做,但我得到的只是一团糟,只有错误。
var options = {
chart: {
type: 'column'
},
title: {
text: 'Basic drilldown'
},
xAxis: {
type: 'category'
},
legend: {
enabled: false
},
plotOptions: {
series: {
borderWidth: 0,
dataLabels: {
enabled: true
}
}
},
series: [{
name: 'People',
colorByPoint: true,
data: [{
name: 'Age group',
y: [],
drilldown: 'Agegroup'
}, {
name: 'Gender',
y: [],
drilldown: 'Gender'
}, {
name: 'Sessions',
y: [],
drilldown: 'Sessions'
}]
}],
drilldown: {
series: [{
id: 'Agegroup',
data: []
}, {
id: 'Gender',
data: []
}, {
id: 'Sessions',
data: []
}]
}
};
var lines = csv.split('\n');
$.each(lines, function (lineNo, line) {
var items = line.split(',');
var agegroup=items[0];
var gender=items[1];
var sessions=parseInt(items[2]);
options.drilldown.series.data.push([gender,sessions]);
此 CSV 数据如下:
18-24,female,313,1
18-24,male,209,1
25-34,female,1941,1
25-34,male,1646,1
35-44,female,980,1
35-44,male,1000,1
45-54,female,244,1
45-54,male,272,1
55-64,female,106,1
55-64,male,104,1
65+,female,36,1
65+,male,52,1
试试这个
var yMale, yFemale;
var sessionDataMale = [];
var sessionDataFemale = [];
var ageGroup = []
$.get('data.csv', function(data) {
var lines = csv.split('\n');
$.each(lines, function(lineNo, line) {
var items = line.split(',');
var agegroup = items[0];
var gender = items[1];
var sessions = parseInt(items[2]);
if (gender == male) {
yMale += sessions;
sessionDataMale.push(sessions)
}
if (gender == female) {
yFemale += sessions
sessionDataFemale.push(sessions)
}
ageGroup.push(agegroup)
}
//creating uniue age group array
var uniqueAgeGroups = []; $.each(ageGroup, function(i, el) {
if ($.inArray(el, uniqueAgeGroups) === -1) uniqueAgeGrops.push(el);
});
var drillDataMale = []
var drillDataFemale = []
for (var i = 0; i < uniqueAgeGroups.length; i++) {
var arrMale = [];
var arrFemale = []
arrMale.push([uniqueAgeGroups[i], sessionDataMale[i]])
arrFemale.push([uniqueAgeGroups[i], sessionDataFemale[i]])
drillDataMale.push(arrMale)
drillDataFemale.push(arrFemale)
}
)
}
// Create the chart
Highcharts.chart('container', {
chart: {
type: 'pie'
},
title: {
text: 'Test'
},
plotOptions: {
series: {
dataLabels: {
enabled: true,
format: '{point.name}: {point.y}'
}
}
},
tooltip: {
headerFormat: '<span style="font-size:11px">{series.name}</span><br>',
pointFormat: '<span style="color:{point.color}">{point.name}</span>: <b>{point.y}</b> of total<br/>'
},
series: [{
name: 'Gender',
colorByPoint: true,
data: [{
name: 'Female',
y: yFemale,
drilldown: 'female'
}, {
name: 'Male',
y: yMale,
drilldown: 'male'
}],
}],
drilldown: {
series: [{
name: 'Age Group',
id: male,
data: drillDataMale
}, {
name: 'Age Group',
id: female,
data: drillDataFemale
}]
}
});
是否可以为以年龄组、性别和访问量作为数据的 csv 数据集创建带有高图的向下钻取饼图? 我一直试图那样做,但我得到的只是一团糟,只有错误。
var options = {
chart: {
type: 'column'
},
title: {
text: 'Basic drilldown'
},
xAxis: {
type: 'category'
},
legend: {
enabled: false
},
plotOptions: {
series: {
borderWidth: 0,
dataLabels: {
enabled: true
}
}
},
series: [{
name: 'People',
colorByPoint: true,
data: [{
name: 'Age group',
y: [],
drilldown: 'Agegroup'
}, {
name: 'Gender',
y: [],
drilldown: 'Gender'
}, {
name: 'Sessions',
y: [],
drilldown: 'Sessions'
}]
}],
drilldown: {
series: [{
id: 'Agegroup',
data: []
}, {
id: 'Gender',
data: []
}, {
id: 'Sessions',
data: []
}]
}
};
var lines = csv.split('\n');
$.each(lines, function (lineNo, line) {
var items = line.split(',');
var agegroup=items[0];
var gender=items[1];
var sessions=parseInt(items[2]);
options.drilldown.series.data.push([gender,sessions]);
此 CSV 数据如下:
18-24,female,313,1
18-24,male,209,1
25-34,female,1941,1
25-34,male,1646,1
35-44,female,980,1
35-44,male,1000,1
45-54,female,244,1
45-54,male,272,1
55-64,female,106,1
55-64,male,104,1
65+,female,36,1
65+,male,52,1
试试这个
var yMale, yFemale;
var sessionDataMale = [];
var sessionDataFemale = [];
var ageGroup = []
$.get('data.csv', function(data) {
var lines = csv.split('\n');
$.each(lines, function(lineNo, line) {
var items = line.split(',');
var agegroup = items[0];
var gender = items[1];
var sessions = parseInt(items[2]);
if (gender == male) {
yMale += sessions;
sessionDataMale.push(sessions)
}
if (gender == female) {
yFemale += sessions
sessionDataFemale.push(sessions)
}
ageGroup.push(agegroup)
}
//creating uniue age group array
var uniqueAgeGroups = []; $.each(ageGroup, function(i, el) {
if ($.inArray(el, uniqueAgeGroups) === -1) uniqueAgeGrops.push(el);
});
var drillDataMale = []
var drillDataFemale = []
for (var i = 0; i < uniqueAgeGroups.length; i++) {
var arrMale = [];
var arrFemale = []
arrMale.push([uniqueAgeGroups[i], sessionDataMale[i]])
arrFemale.push([uniqueAgeGroups[i], sessionDataFemale[i]])
drillDataMale.push(arrMale)
drillDataFemale.push(arrFemale)
}
)
}
// Create the chart
Highcharts.chart('container', {
chart: {
type: 'pie'
},
title: {
text: 'Test'
},
plotOptions: {
series: {
dataLabels: {
enabled: true,
format: '{point.name}: {point.y}'
}
}
},
tooltip: {
headerFormat: '<span style="font-size:11px">{series.name}</span><br>',
pointFormat: '<span style="color:{point.color}">{point.name}</span>: <b>{point.y}</b> of total<br/>'
},
series: [{
name: 'Gender',
colorByPoint: true,
data: [{
name: 'Female',
y: yFemale,
drilldown: 'female'
}, {
name: 'Male',
y: yMale,
drilldown: 'male'
}],
}],
drilldown: {
series: [{
name: 'Age Group',
id: male,
data: drillDataMale
}, {
name: 'Age Group',
id: female,
data: drillDataFemale
}]
}
});