- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个包含 DC 行图和直方图(DC 条形图)的仪表板。我的数据集有 100 行和 10 个字段。六个字段具有全部 100 个数据点,而其他四个字段具有 95 个数据点和 5 个空白。我需要以一种对用户透明的方式在一个仪表板上显示所有字段。
对于行图表,我只是绘制空白并使用 .label() 属性将行名称设置为“未分配”,其中有空白。
对于直方图,我被卡住了。我想显示一个标记为“未分配”的列,以及直方图的正常线性列。也可以从直方图中隐藏空白行。
我无法过滤直方图背后的维度,因为这会从交叉过滤变量 facts 中删除行,这意味着我看不到包含它们的六个字段的那些行。
标准的假组不起作用,因为对于直方图,当我们到达组时,我们已经有了数字桶,所以不存在键为空白的组。
留给自己,DC 将空白解释为零并相应地对它们进行存储。我尝试限制维度,这是因为零桶减少了 5:
var dim = facts.dimension(function(d){ if (d[field]!='') { return Math.floor(+d[field]/binwidth)*binwidth; } });
但是这样做,5 行的计数只是随机(看起来)分布在其他桶中。当我点击行图上的“未分配”时,直方图随机显示 5 个桶,有时是两个桶,而我认为它们应该什么都不显示。
我可以数出空白行(并不总是 5 行),并想知道我是否可以通过一个假组从零 bin 中减去它。但我无法弄清楚如何添加键值对或调整 key=0 的现有值;
var grp = dim.group().reduceCount();
var grp2 = {all: function() { return grp.top(Infinity); }};
我无法通过 print_filter 或 console.log 看到足够的结构来确定如何更改它。抱歉问题的长度。任何帮助表示赞赏!
艾玛
最佳答案
将它们放入单独的列中会很棘手,因为线性 x 标度不能很好地适应额外/NA/非数值。
我认为您必须切换到序数刻度才能将数字列和非数字列放在一起。有点乱,但可能。
让我们关注更简单的想法,只是跳过这些值。我认为您走在正确的轨道上。
问题是您的维度键函数并不总是返回一个值:
var dim = facts.dimension(function(d){
if (d[field]!='') {
return Math.floor(+d[field]/binwidth)*binwidth;
}
});
else 分支刚刚通过,JavaScript 函数的隐式返回值是 undefined
。所以你最终得到了一些数字键,以及一些带有 undefined
键的行。我不确定 crossfilter 将如何处理这些行,但由于 documentation specifies that the key function must returned naturally-ordered values ,我猜它会感到困惑。
相反,也许让这个函数返回一个远远超出直方图范围的值?
var dim = facts.dimension(function(d){
if (d[field]!='') {
return Math.floor(+d[field]/binwidth)*binwidth;
}
else return -1000;
});
然后很容易创建一个fake group that screens out a particular value :
function remove_bins(source_group) { // (source_group, bins...}
var bins = Array.prototype.slice.call(arguments, 1);
return {
all:function () {
return source_group.all().filter(function(d) {
return bins.indexOf(d.key) === -1;
});
}
};
}
var grp = remove_bins(dim.group(), -1000);
关于javascript - DC.js - 空白数据点和直方图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42153965/
我是 dc.js 的新手,我对 dc 的灵 active 有一些疑问。 首先,我一直在寻找答案,但还没有找到任何答案。 1) 我正在使用 dc.sunburst 图表。我想知道是否有可能创建 Zoom
谁能解释一下 ldap 字符串部分的构成。 我有一个是: string strSQL = "SELECT mail FROM 'LDAP://DC=amrs,DC=win,DC=ml,dc=COM'
他们已经就如何将 dc.js 简单地用作图形库(例如绘制饼图、条形图...)而不需要交叉过滤器进行了各种讨论,例如,如果您只想在数据已经是一个(标签,值)。 我没有找到任何关于如何做到这一点的例子。这
当我点击数据表中的一行时,我需要过滤其他图表。 我做了 my_table.on('pretransition', function (table) { table.selectAll('td
我想显示小切片( chart.minAngleForLabel(0.05) )的标签,避免文本重叠。 我添加了一个将标签移向外边缘的renderlet: .on('renderlet', func
如何在新列的 dc.js 数据表中添加带有事件监听器的按钮。 如果可能的话,我基本上想添加自定义 html。 最佳答案 添加按钮只是返回列的 html 的问题 dc.dataTable (dom) .
这个问题在这里已经有了答案: Initial Range selection in DC.js chart (1 个回答) 关闭 7 年前。 我创建了 this可视化,并希望在解释文本中使用预定义的
我用 dc.js 制作了一个热图,我想知道 dc.js 中是否有热图的键或图例函数。我在互联网上搜索过,但似乎找不到内置的方法,那么有没有其他人解决过这个问题? 最佳答案 我遇到了同样的任务,我所做的
我有一个具有以下模型的数据源: [ { days : 3, value : 500 }, { days : 30,
如果过滤后 dc.js 中的行图值为零,我们如何隐藏。我们有这样的代码: var kurum=data.dimension(function(d){return ""+ d.KURUM;});
自 1.4.0-alpha.06 版起,Crossfilter 支持数组维度 https://github.com/crossfilter/crossfilter/wiki/API-Reference
我希望在 dc.js 的多维数据集中绘制与连续变量关联的几个直方图。虽然使用 dc.barChart 组件很容易实现这一点,但我希望对这些直方图进行面积归一化。在我的例子中,bin 宽度是统一的,所以
我目前正在尝试弄清楚如何使用 DJ.js 和 D3.js 计算要显示的唯一记录数 数据集如下所示: id,name,artists,genre,danceability,energy,key,loud
在此图表上:http://junklogic.com/dcjs/barpie/index-controls.html 我的示例 JSON 文件中有与严重性评级相对应的图例,该文件代表我将在生产中使用的
我有以下数据。 我可以使用 dc.js 创建一个吗? 有人可以帮助我使用 dc js 创建直方图吗? 搜索了整个论坛但除了这个post 找不到有用的东西. 日期: numbers11012035242
以下是一组数据: var data = [{ machine1: [ {x:"20/12/2014", y:2}, {x:"21/12/2014", y:10} ]},{ machine2:
我使用 dc.js 和 crossfilter 创建了一个折线图。当前图表如下所示: 必需:我希望左上角的事件非事件图例位于中心图表的下方(底部),并且 x 轴刻度标签应该从一月到十二月开始。我在下面
我仍在尝试使用 dc 和 crossfilter 将图表链接在一起,这里我将表格和饼图链接在一起。链接在图表和表格之间起作用,因此当我单击饼图时,表格会相应更新。 然而,当我点击超链接时,这一行似乎没
我对允许打印填充填充对象的修复有疑问... 所以,完整的故事是我们使用了 Windows GDI FloodFill 函数,我们注意到它在打印机上不起作用,所以我在 inet 上找到的是创建一个内存
我是 MFC 编程的新手。这些天我正在使用 Jeff Prosise 的书来学习 MFC 编程。我遇到过:CClientDC dc (this); 我从 CClientDC 类的定义中找到了一个构造函
我是一名优秀的程序员,十分优秀!