- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试绘制一个包含多个系列的图表。它的数据来自数据库,通过 DataAdapter
进入 DataTable
,如下所示;
public DataTable deaths_per_reason_per_year(string farmerid)
{
dt = new DataTable();
try
{
conn.Open(); // (select formatted to fit SO lines)
SqlCommand cmd = new SqlCommand("SELECT DATEPART(yyyy, DeathDate) AS 'Year',
Reason,
COUNT(DeathID) AS 'Number of Deaths' FROM [Farmstat_V1.0].[dbo].[Death]
WHERE FarmerID = '" + farmerid + "'
GROUP BY Reason, YEAR(DeathDate);", conn);
SqlDataReader reader = cmd.ExecuteReader();
dt.Load(reader);
}
catch (Exception)
{
throw;
}
finally
{
conn.Close();
}
return dt;
}
这给了我以下输出;
当我尝试将 DataTable 分配给表单上的图表时,用这个;
StatsDataAccess sda = new StatsDataAccess();
chart1.DataSource = sda.deaths_per_reason_per_year(FarmerID);
chart1.Series["Series1"].XValueMember = "Year";
chart1.Series["Series1"].YValueMembers = "Number of Deaths";
chart1.Series["Series2"].XValueMember = "Reason";
chart1.Series["Series2"].YValueMembers = "Number of Deaths";
chart1.ChartAreas["ChartArea1"].AxisX.MajorGrid.Enabled = false;
chart1.Series["Series1"].IsValueShownAsLabel = true;
chart1.DataBind();
我得到了一个看起来像这样的绘制图表,我已经通过图表的属性 Pane 在其中添加了系列;
但我想要一个应该看起来像这样的输出;
我试过 googleing 但没有成功。有人可以帮我解决这个问题吗?我会非常感激。谢谢
最佳答案
最明显的问题是关于 x 值的数据类型。
所有 X 值在内部都是 double
类型。
简介
DataPoints
,它们将按预期处理和存储DataPoints
和 DateTime
X 值,它们也会转换为 double 值(通过 OLE 自动化日期转换)但是如果你添加不能转换为数字的类型,比如字符串,事情就会变得很奇怪。 在内部 X 值都是0
,因为除了标签显示 字符串之外它们还能是什么。
显示的 DataPoints
被视为具有 0,1,2,3... 的 X 值,并且这些点以漂亮且相等的间距显示。
对于许多新手来说,这看起来不错,他们永远不知道他们实际上失去了 X 值。
当尝试使用数字格式或尝试使用 X 值进行计算时,他们的问题就来了。
你的问题
你的“问题”是你的 select
从 DATEPART
函数中传递整数,所以你做对了,事实上你做得太好了,无法计算出盒子..
听起来非常不错而且是..
..然而 Chart
尝试显示许多具有 Auto
设置的项目,虽然它们通常 工作正常,但在这里他们不这样做,因为他们试图从 x = 0
开始图表,当然 2014-2016
的三个实际值被挤到右边,面目全非。
解决方法很简单:设置显示最小值:
chart1.ChartAreas["ChartArea1"].AxisX.Minimum = 2014;
一切顺利。您可能希望根据 Points
中的 x 值计算该值,万岁,您可以,因为您拥有它们..
这是最好的方法,只要您的系列具有有意义的 X 值数字。
不幸的是,第二个系列似乎没有......
丑陋的替代方法是将年份转换为字符串,但是,除非你真的必须这样做,否则不要这样做!
解决缩放问题后,您的代码的另一个大问题变得可见:
您的数据映射有误。
比较数据表和所需的输出,您的数据绑定(bind)根本不会映射到那样的图表。
解决方案:您应该将数据分成尽可能多的独立来源,因为您有原因
,即因为您有系列
要绑定(bind)。
我会为每个 reason
创建一个单独的 DataViews
,每个都基于相同的 DataTable
但具有不同的 Filter
(reason = 'reason1'..) 然后将每个 DataView
绑定(bind)到一个 Series
。
在我的脑海中,这就是它的样子:
DataTable DT = yourTable;
DataView dv1 = new DataView(DT);
DataView dv2 = new DataView(DT);
..
dv1.RowFilter = "reason=='Sold'";
dv2.RowFilter = "reason=='Other'";
..
yourSeries1.Points.DataBind(dv1, "year", "deathcount", "");
..
现在所有 Series DataPoints
都以相同的方式绑定(bind),所有 Series
显示并且缩放比例固定。
关于c# - 从数据表绘制图表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33588055/
我有一个带有嵌套数据的 angular 数据表,我正在尝试在行点击函数上创建另一个数据表。父数据表的 rowCallBack 函数。 这是我的外部数据表 html; 这是我生成数据表的方
我有一个字母数字列,其中包含诸如“1、2、2”之类的字符串。 当我在搜索中输入“1, 2, 2”时,它似乎返回带有“1,”和“2,”的所有单元格。 我该怎么做才能使搜索仅返回“1、2、2”? 使用数据
我有一个获取其数据服务器端的表,使用自定义服务器端初始化参数,这些参数因生成的报告而异。表格生成后,用户可以打开一个弹出窗口,他们可以在其中添加多个附加过滤器以进行搜索。我需要能够使用与原始表相同的初
在 datatables我希望能够隐藏所有列,但似乎无法正确使用语法。 这来自下面的代码和上面的链接,创建了一个显示所有列的按钮。有没有办法写这个以便我可以隐藏所有列? {
我正在使用 DataTable 创建一个交互式表。我有 9 列,其中 5 列是值。我想根据它们的具体情况更改每个单元格的背景颜色。 我已经开始尝试首先更改整行颜色,因为这似乎是一项更容易的任务。但是我
我有一个简单的例子来说明我的问题。我正在使用数据表 1.9。当数据表位于另一个 html 表内时,水平滚动时列标题不会移动。当它不在 html 表中时它工作正常。我的示例实际上取自他们的水平滚动示例,
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
这是添加按钮以将数据导出到 csv、pdf、excel 的数据表示例...... fiddle here https://datatables.net/extensions/buttons/examp
是否有任何方法可以更改 angularjs 数据表中的按钮样式(colvis、copy、print、excel)。 vm.dtOptions = DTOptionsBuilder.newOptions
我试图弄清楚如何加入 2 个数据表并更新第一个但应用了过滤器。 DT DT2 b c 1: 1 10 2: 2 10 3: 3 10 4: 4 10 5: 5 10 6: 6 10 7: 7 10
我有一个数据表,其中包含许多包含值的列。我还有另一列,它定义了我需要选择哪些列的值。我很难找到一种方法来做到这一点。 这是一个简单的例子。 > d d value.1 value.2 name
我正在使用 data.table 包。我有一个数据表,表示用户在网站上的操作。假设每个用户都可以访问一个网站,并对其执行多项操作。我的原始数据表是 Action (每一行都是一个 Action ),我
我想知道每个变量在每个组中变化了多少次,然后将结果添加到所有组中。 我是这样找到的: mi[,lapply(.SD, function(x) sum(x != shift(x), na.rm=T)
有人可以向我解释一下如何向页眉或页脚添加按钮吗?Datatables 的开发者 Alan 说你必须离开网络服务器才能使用 Table Tools 来使用按钮。但我在独立计算机上离线运行 Datatab
我希望按 id 和按顺序(时间)计算不同的东西。 例如,与: dt = data.table( id=c(1,1,1,2,2,2,3,3,3), hour=c(1,5,5,6,7,8,23,23,23
我正在尝试在 JIRA 小工具中使用数据表,但在我的表准备就绪后,没有可用的分页按钮。我有一个表,我正在以最简单的方式使用数据表:$("#mytableid").dataTable(); 浏览页面元素
我有 responsive 表单中的数据表。 数据表生成 child rows在小型设备上。在这一行中,我有一些输入控件。这会导致两个问题。 第一个问题:**隐藏子行中的值不会进入表单数据。** 第二
我在使用 JQuery DataTable 捕获 keydown 事件时遇到问题。我的目标是允许用户使用箭头键导航表的行。因此,当用户按下箭头键时,我想捕获 keydown 事件并移动表的选定行(这是
是否有任何方法可以以编程方式更改显示的行数,而无需从下拉列表中手动选择? 我已经知道如何更改默认行数。当表首次加载时,我希望它加载所有行,然后“刷新”表以可能仅显示前 10 行。但我想以编程方式刷新表
我有一个数据表,我应该对其进行更改,例如我想更改内容的状态,但该内容位于表的第三页。当我更改它时,数据表会自行刷新到第一页。我想做的是保留选定的页码并在刷新后回调它。这可能吗? 顺便说一句,我正在使用
我是一名优秀的程序员,十分优秀!