数据如下

统计效果图如下

程序初始化

 private void Form1_Load(object sender, EventArgs e)
{
using (SqlConnection con = new SqlConnection("server=.;pwd=123456;uid=sa;database=db_TomeOne"))
{
SqlDataAdapter da = new SqlDataAdapter("select Years from tb_curve", con);
DataTable dt = new DataTable();
da.Fill(dt);
this.comboBox1.DataSource = dt.DefaultView;
this.comboBox1.DisplayMember = "Years";
this.comboBox1.ValueMember = "Years";
}
}

按钮点击

private void button1_Click(object sender, EventArgs e)
{
this.CreateImage(Convert.ToInt32(this.comboBox1.Text));
}
        private void CreateImage(int ID)
{
int height = 440, width = 600; //设置画布宽和高
System.Drawing.Bitmap image = new System.Drawing.Bitmap(width, height);//创建画布
Graphics g = Graphics.FromImage(image); //创建Graphics对象
try
{
g.Clear(Color.White); //清空图片背景色
Font font = new System.Drawing.Font("Arial", 9, FontStyle.Regular); //设置字体
Font font1 = new System.Drawing.Font("宋体", 12, FontStyle.Regular); //设置字体
Font font2 = new System.Drawing.Font("Arial", 8, FontStyle.Regular); //设置字体
System.Drawing.Drawing2D.LinearGradientBrush brush = new System.Drawing.Drawing2D.LinearGradientBrush(new Rectangle(0, 0, image.Width, image.Height), Color.Blue, Color.Blue, 1.2f, true); //创建LinearGradientBrush对象
g.FillRectangle(Brushes.AliceBlue, 0, 0, width, height); //绘制矩形框
Brush brush1 = new SolidBrush(Color.Blue); //创建笔刷
Brush brush2 = new SolidBrush(Color.SaddleBrown); //创建笔刷
string str = "SELECT * FROM tb_curve WHERE Years=" + ID + ""; //声明SQL语句
SqlConnection Con = new SqlConnection("server=.;pwd=123456;uid=sa;database=db_TomeOne");//建立数据库连接
Con.Open(); //打开数据库连接
SqlCommand Com = new SqlCommand(str, Con); //创建SqlCommand对象
SqlDataReader dr = Com.ExecuteReader(); //创建SqlDataReader对象
dr.Read(); //开始读取记录
if (dr.HasRows) //如果有记录
{
//绘制标题
g.DrawString("" + ID + "年公司内部人员统计表", font1, brush1, new PointF(160, 30));
}
dr.Close(); //关闭SqlDataReader对象
//画图片的边框线
g.DrawRectangle(new Pen(Color.Blue), 0, 0, image.Width - 1, image.Height - 1);
Pen mypen = new Pen(brush, 1); //创建画笔
Pen mypen2 = new Pen(Color.Red, 2); //创建画笔
int x = 60;
for (int i = 0; i < 12; i++)
{
g.DrawLine(mypen, x, 80, x, 340); //绘制纵向线条
x = x + 40;
}
Pen mypen1 = new Pen(Color.Blue, 2); //创建画笔
g.DrawLine(mypen1, x - 480, 80, x - 480, 340); //绘制线条
int y = 106;
for (int i = 0; i < 9; i++)
{
g.DrawLine(mypen, 60, y, 540, y); //绘制横向线条
y = y + 26;
}
g.DrawLine(mypen1, 60, y, 540, y);
//x轴
String[] n = {" 一月", " 二月", " 三月", " 四月", " 五月", " 六月", " 七月",
" 八月", " 九月", " 十月", "十一月", "十二月"}; //绘制月份
x = 35;
for (int i = 0; i < 12; i++)
{
g.DrawString(n[i].ToString(), font, Brushes.Red, x, 348); //设置文字内容及输出位置
x = x + 40;
}
//y轴
String[] m = {"900人", " 800人", " 700人", "600人", " 500人", " 400人", " 300人", " 200人",
" 100人"}; //绘制人数
y = 100;
for (int i = 0; i < 9; i++)
{
g.DrawString(m[i].ToString(), font, Brushes.Red, 10, y); //设置文字内容及输出位置
y = y + 26;
}
int[] Count1 = new int[12];
int[] Count2 = new int[12];
string[] NumChr = new string[12];
string cmdtxt2 = "SELECT * FROM tb_curve WHERE Years=" + ID + ""; //声明SQL语句
SqlCommand Com1 = new SqlCommand(cmdtxt2, Con); //创建SqlCommand对象
SqlDataAdapter da = new SqlDataAdapter(); //创建SqlDataAdapter对象
da.SelectCommand = Com1;
DataSet ds = new DataSet(); //创建DataSet对象
da.Fill(ds); //Fill方法填充DataSet
int j = 0;
for (int i = 0; i < 12; i++)
{
NumChr[i] = ds.Tables[0].Rows[0][i + 1].ToString();
}
for (j = 0; j < 12; j++)
{
Count1[j] = Convert.ToInt32(NumChr[j].Split('|')[0].ToString()) * 26 / 100;
}
for (int k = 0; k < 12; k++)
{
Count2[k] = Convert.ToInt32(NumChr[k].Split('|')[1].ToString()) * 26 / 100;
}
//显示折线效果
SolidBrush mybrush = new SolidBrush(Color.Red); //创建SolidBrush对象
Point[] points1 = new Point[12];
points1[0].X = 60; points1[0].Y = 340 - Count1[0];
points1[1].X = 100; points1[1].Y = 340 - Count1[1];
points1[2].X = 140; points1[2].Y = 340 - Count1[2];
points1[3].X = 180; points1[3].Y = 340 - Count1[3];
points1[4].X = 220; points1[4].Y = 340 - Count1[4];
points1[5].X = 260; points1[5].Y = 340 - Count1[5];
points1[6].X = 300; points1[6].Y = 340 - Count1[6];
points1[7].X = 340; points1[7].Y = 340 - Count1[7];
points1[8].X = 380; points1[8].Y = 340 - Count1[8];
points1[9].X = 420; points1[9].Y = 340 - Count1[9];
points1[10].X = 460; points1[10].Y = 340 - Count1[10];
points1[11].X = 500; points1[11].Y = 340 - Count1[11];
g.DrawLines(mypen2, points1); //绘制折线
Pen mypen3 = new Pen(Color.Black, 2); //创建画笔
Point[] points2 = new Point[12];
points2[0].X = 60; points2[0].Y = 340 - Count2[0];
points2[1].X = 100; points2[1].Y = 340 - Count2[1];
points2[2].X = 140; points2[2].Y = 340 - Count2[2];
points2[3].X = 180; points2[3].Y = 340 - Count2[3];
points2[4].X = 220; points2[4].Y = 340 - Count2[4];
points2[5].X = 260; points2[5].Y = 340 - Count2[5];
points2[6].X = 300; points2[6].Y = 340 - Count2[6];
points2[7].X = 340; points2[7].Y = 340 - Count2[7];
points2[8].X = 380; points2[8].Y = 340 - Count2[8];
points2[9].X = 420; points2[9].Y = 340 - Count2[9];
points2[10].X = 460; points2[10].Y = 340 - Count2[10];
points2[11].X = 500; points2[11].Y = 340 - Count2[11];
g.DrawLines(mypen3, points2); //绘制折线
//绘制标识
g.DrawRectangle(new Pen(Brushes.Red), 150, 370, 250, 50); //绘制范围框
g.FillRectangle(Brushes.Red, 250, 380, 20, 10); //绘制小矩形
g.DrawString("试用员工人数", font2, Brushes.Red, 270, 380); //绘制试用员工人数
g.FillRectangle(Brushes.Black, 250, 400, 20, 10); //绘制小矩形
g.DrawString("正式员工人数", font2, Brushes.Black, 270, 400); //绘制正式员工人数
this.panel1.BackgroundImage = image; //显示绘制的图像
}
catch
{ }
}

C#多曲线数据分析的更多相关文章

  1. R数据分析:临床预测模型中校准曲线和DCA曲线的意义与做法

    之前给大家写过一个临床预测模型:R数据分析:跟随top期刊手把手教你做一个临床预测模型,里面其实都是比较基础的模型判别能力discrimination的一些指标,那么今天就再进一步,给大家分享一些和临 ...

  2. 脑成像数据分析:Python工具包

    来源:SealHuang 脑成像技术已经成为认知科学和心理学研究领域中一种重要的研究手段,帮助研究者不断深入发掘我们脑中的秘密.伴随着研究的不断深入,各式各样的指标参数和分析方法也不断推陈出新,以迅雷 ...

  3. 基于SPSS的美国老年夏季运动会运动员数据分析

             本文是课程训练的报告,部分图片由于格式原因并没有贴出,有兴趣者阅读完整报告者输入以下链接 http://files.cnblogs.com/files/liugl7/基于SPSS的老 ...

  4. 小白学数据分析----->DNU/DAU

    行业指标观察分析-DNU/DAU 写在分析之前 一直以来,我们对于数据都是在做加法,也希望这个过程中,不断搜罗和变换出来更多的数据指标,维度等等.而在实际的分析中,我们发现,一如我们给用户提供产品一样 ...

  5. Gartner: Hype Cycle for Emerging Technologies-2012 (技术成熟度曲线) [转]

      英文稿: The “Hype Cycle for Emerging Technologies” report is the longest-running annual Hype Cycle, p ...

  6. 六行python代码的爱心曲线

    前些日子在做绩效体系的时候,遇到了一件囧事,居然忘记怎样在Excel上拟合正态分布了,尽管在第二天重新拾起了Excel中那几个常见的函数和图像的做法,还是十分的惭愧.实际上,当时有效偏颇了,忽略了问题 ...

  7. 【读书笔记与思考】《python数据分析与挖掘实战》-张良均

    [读书笔记与思考]<python数据分析与挖掘实战>-张良均 最近看一些机器学习相关书籍,主要是为了拓宽视野.在阅读这本书前最吸引我的地方是实战篇,我通读全书后给我印象最深的还是实战篇.基 ...

  8. python数据分析工具包(3)——matplotlib(一)

    前两篇文章简单介绍了科学计算Numpy的一些常用方法,还有一些其他内容,会在后面的实例中学习.下面介绍另一个模块--Matplotlib. Matplotlib是一个Python 2D绘图库,试图让复 ...

  9. python 数据分析工具之 numpy pandas matplotlib

    作为一个网络技术人员,机器学习是一种很有必要学习的技术,在这个数据爆炸的时代更是如此. python做数据分析,最常用以下几个库 numpy pandas matplotlib 一.Numpy库 为了 ...

  10. 《python for data analysis》第二章,美国1880-2010年出生人口姓名的数据分析

    <利用python进行数据分析>第二章的姓名例子,代码.整个例子的所有代码集成到了一个文件中,导致有些对象名如year同时作为了列名与行名,会打印warning,可分不同的part依次运行 ...

随机推荐

  1. Kylin Linux Advanced Server V10 上安装 Nacos详细步骤

    要在 Kylin Linux Advanced Server V10 上安装 Nacos,可以按照以下进行操作:1.安装 Java JDK:首先确保已在 Kylin Linux Advanced Se ...

  2. 吉特日化MES & 标签的设计与选择

    吉特日化MES & 标签的设计与选择:如今条码和二维码在生活中随处可见,作为一种能够快速精准读取识别的手段,条码和二维码在生产车间也应用的较为广泛.如果说条码和二维码哪一种更好,我更加倾向于使 ...

  3. MySQL运维10-Mycat分库分表之一致性哈希分片

    一.一致性哈希分片 一致性哈希分片的实现思路和我们之前介绍的水平分表中的取模分片是类似的.只不过取模分片,采用的是利用主键和分片数进行取模运算,然后根据取模后的结果,将数据写入到不同的分片数据中.但是 ...

  4. 在arm架构的银河麒麟系统部署Nginx

    以下是在arm架构的银河麒麟系统上部署Nginx的详细步骤: 1. 创建文件夹 首先,在合适的位置创建必要的文件夹.在本例中,我们将创建/opt/nginx和/usr/src/nginx两个文件夹. ...

  5. 【2016】CloneCD和IsoBuster配合使用以提取VCD中的文件

    **笔记记录于:2016-11-24 ** 本文章仅供用于技术研究用途,请勿利用文章内容操作用于违反法律的事情. 起因: 公司老总让我提取下VCD中的文件以备份下,但是把光碟放进DVD光驱中发现只有几 ...

  6. hszxoj 矿场搭建 [tarjan]

    hszxoj 矿场搭建 题目描述 原题来自:HNOI 2012 煤矿工地可以看成是由隧道连接挖煤点组成的无向图.为安全起见,希望在工地发生事故时所有挖煤点的工人都能有一条出路逃到救援出口处.于是矿主决 ...

  7. NC65元数据添加七彩版时注意点

    元数据添加七彩版时注意点 元数据七彩版模式 --- 主要添加Xml文件调整格式 添加时注意点如下 手动创建Panel时 自动生成的实现方法中有一个方法的返回值一定要为true 该方法主要是控制显不显示 ...

  8. ElasticSearch之cat thread pool API

    命令样例如下: curl -X GET "https://localhost:9200/_cat/thread_pool?v=true&pretty" --cacert $ ...

  9. Android移动、缩放和旋转手势实现

    Android的部分图片编辑应用中需要对图片进行移动.缩放和旋转,这些变化都依赖于触摸手势实现,而本文主要阐述移动.缩放和旋转手势的简单实现. 一.移动 首先需要从触摸事件(MotionEvent)中 ...

  10. MYSQL事务篇(高级篇)

    1.事务介绍: 一般是指要做的或所做的事情. 在计算机 术语 中是指访问并可能更新数据库中各种 数据项 的一个程序 执行单元 (unit) 2.数据库事务具有ACID四大特性. ACID是以下4个词的 ...