程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> 泛型集合小項目員工打卡,集合員工打卡

泛型集合小項目員工打卡,集合員工打卡

編輯:關於C語言

泛型集合小項目員工打卡,集合員工打卡


 

項目樣式

需求說明:1.實現新增員工

     2.使用DataGrideView空間展示員工信息

     3.實現刪除員工信息

     4.給主窗體添加右鍵菜單,實現上班簽到和下班簽退

     5.選擇簽到,必須檢索員工打卡記錄,如果已簽到,提示不能再簽到

     6.選擇簽退,必須檢索員工打卡記錄,如果已簽退,提示不能再簽退

     7.使用DataGrideView控件顯示員工考勤記錄

 

項目開始:

首先搭好窗體,創建員工類 SE 打卡時間類

public class SE
{

public int id{ get; set; }      //存儲員工工號
public string name { get; set; }  //存儲員工姓名
public int age { get; set; }     //存儲員工年齡
public string sex{ get; set; }   //存儲員工
public int type;          //存儲打卡類型1,2,3
}

 

public class Time
{
public DateTime start { get; set; } //存儲簽到時間
public DateTime close { get; set; } //存儲簽退時間
public int id { get; set; }      //存儲打卡類型1,2,3
public string name { get; set;}   //存儲員工姓名

}

然後創建泛型集合list

public List<SE> list = new List<SE>();   //存儲員工的集合
public static Dictionary<string, Time> dic = new Dictionary<string, Time>(); //存儲打卡記錄

 

在窗體load時間為DataGrideView綁定數據源

SE s1 = new SE();
s1.id = 111;
s1.name = "王小毛";
s1.age = 26;
s1.sex = "男";
SE s2 = new SE();
s2.id = 112;
s2.name = "周新雨";
s2.age = 22;
s2.sex = "女";
SE s3 = new SE();
s3.name = "張烨";
s3.id = 113;
s3.age = 30;
s3.sex = "男";
list.Add(s1);
list.Add(s2);
list.Add(s3);
dataGridView1.DataSource = list;

新增就是跳轉新增員工窗體

點擊新增將新員工信息保存到集合中

SE s = new SE();
s.id = Convert.ToInt32(textBox1.Text);
s.name = textBox2.Text;
s.age = Convert.ToInt32(textBox3.Text);
s.sex = textBox4.Text;
frm1.list.Add(s);
MessageBox.Show("新RR增成功!");
frm1.Show();
frm1.clear(frm1.list);
this.Close();  

修改員工信息涉及到一個窗體傳值,這次我們傳的是一個SE對象

首先在修改員工信息窗體new一個新的SE對象

然後點擊主窗體的修改,跳轉修改員工信息窗體

Form3 frm = new Form3();
frm.name = dataGridView1.SelectedCells[1].Value.ToString();
foreach (SE s in list)
{
if (s.id.ToString() == dataGridView1.SelectedCells[0].Value.ToString())
{
frm.s = s;
break;
}
}
frm.f = this;
frm.Show();
this.Hide();

跳轉到修改員工信息窗體,可以在textBox編輯員工信息

點擊修改,保存數據

SE s = new SE();
s.id = Convert.ToInt32(textBox1.Text);
s.age = Convert.ToInt32(textBox3.Text);
s.sex = textBox4.Text;
for(int i = 0; i < f.list.Count; i++)
{
if (f.list[i].name == name)
{
f.list[i].age = Convert.ToInt32(textBox3.Text);
f.list[i].id = Convert.ToInt32(textBox1.Text);
f.list[i].sex = textBox4.Text;
break;
}
}
MessageBox.Show("修改成功!");
f.clear(f.list);
f.Show();

在主窗體的DataGrideView添加ContextMenuTrip,添加簽到和簽退

點擊簽到和簽退,分別在集合中添加一條數據

string name=dataGridView1.SelectedCells[1].Value.ToString();
SE s = new SE();
foreach (SE se in list)
{
if (se.name == name)
{
s = se;
break;
}
}
num = s.type;
if (num==0)
{
Time t = new Time();
t.id = Convert.ToInt32(dataGridView1.SelectedRows[0].Cells[0].Value);
t.name = dataGridView1.SelectedRows[0].Cells[1].Value.ToString();
t.start = DateTime.Now;
dic.Add(t.name, t);
s.type = 1;
MessageBox.Show("簽到成功~");
}
else
{
MessageBox.Show("你已經簽到過了");
}

同時判斷是否已簽到,簽退與之相同

點擊打卡記錄,就可以看到員工打卡的信息了

這樣,一個簡單的小程序就寫完了

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved