今天上午进行了公司的C# C level考核,最后一道编程题是关于员工信息系统的,题目的要求大概是这样的:1、要可以保存员工信息(XXXXX),并且要用正则表达式对输入信息进行验证;2、要可以对员工信息进行查询(根据员工号和部门两种方式)。

我是通过窗体程序实现的,窗体设计如下,一共三个,分别是主窗体界面、添加员工信息窗体和查找员工信息窗体:

程序如下:

主窗体——

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Xml;
using System.Xml.Linq;
using System.IO; namespace WorkmatesInfoSystem
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
} private void button1_Click(object sender, EventArgs e)
{
AddInfo addInfoForm = new AddInfo();
addInfoForm.ShowDialog();
} private void button2_Click(object sender, EventArgs e)
{
SearchInfo searchInfoForm = new SearchInfo();
searchInfoForm.ShowDialog();
}
}
}

添加员工信息窗体:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Text.RegularExpressions;
using System.Xml;
using System.Xml.Linq;
using System.IO; namespace WorkmatesInfoSystem
{
public partial class AddInfo : Form
{
public AddInfo()
{
InitializeComponent();
} private void textBox1_Click(object sender, EventArgs e)
{
if(WorkerNumber.Text == "The worker's nubmer must be a number(not a string or etc).")
{
WorkerNumber.Text = "";
}
} private void textBox2_Click(object sender, EventArgs e)
{
if (WorkerName.Text == "Herry(For example)")
{
WorkerName.Text = "";
}
} private void textBox3_Click(object sender, EventArgs e)
{ if (WorkerEmail.Text == "The format should like \"tylan@Avpoint.com\"")
{
WorkerEmail.Text = "";
}
} private void textBox4_Click(object sender, EventArgs e)
{
if (WorkerDepartment.Text == "CC_CIQA(For example)")
{
WorkerDepartment.Text = "";
}
} private void button1_Click(object sender, EventArgs e)
{
//Check the format of the worker's number.
if (Regex.IsMatch(WorkerNumber.Text, "^[0-9]*$") == false)
{
MessageBox.Show("Worker's number is in a wrong format, please type in again.");
}
//Check the Email's format of the worker.
else if (Regex.IsMatch(WorkerEmail.Text,@"^\w+@\w+$") == false)
{
MessageBox.Show("Worker's Email is in a wrong format, please type in again.");
}
//Check the end format of the Email Address.
else if (Regex.IsMatch(EmailEndFormat.Text, "^(com|net)$") == false)
{
MessageBox.Show("The end format of the Email is wrong, please type in again. You can type in 'com' or 'net'.");
}
//Add the worker's info into the xml.
else
{
saveToXml(SavePath.Text.ToString());
MessageBox.Show("Save the worker's info successfully.");
}
} //Save to XML method.
private void saveToXml(string xmlPath)
{
string filePath = xmlPath + "WorkersInfo.xml";
FileInfo file = new FileInfo(@filePath);
if (file.Exists == false)
{
File.Create(@filePath).Close();
StreamWriter sw = new StreamWriter(@filePath);
string content = "<?xml version=\"1.0\" encoding=\"utf-8\"?>" +
"<System xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\">" +
"<SystemName>WorkersInfo</SystemName>" +
"<Workers>" +
"</Workers>" +
"</System>";
sw.WriteLine(content);
sw.Close();
}
//Load XML file.
XElement xe = XElement.Load(@filePath);
//Create a node info.
XElement Worker = new XElement("Worker",
new XElement("WorkerNumber", WorkerNumber.Text),
new XElement("WorkerName", WorkerName.Text),
new XElement("WorkerEmail", WorkerEmail.Text + "." + EmailEndFormat.Text),
new XElement("WorkerDepartment", WorkerDepartment.Text)
);
//Add the node under the specific node.
xe.Element("Workers").Add(Worker);
//Save the XML file.
xe.Save(filePath);
} private void SavePath_Click(object sender, EventArgs e)
{
if(SavePath.Text==@"C:\Tylan\Workers(For example)")
{
SavePath.Text = "";
}
}
}
}

查找员工信息窗体:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Xml;
using System.Xml.Linq;
using System.IO; namespace WorkmatesInfoSystem
{
public partial class SearchInfo : Form
{
public SearchInfo()
{
InitializeComponent();
} private void SearchDepartmentButton_Click(object sender, EventArgs e)
{
XDocument workersInfo = XDocument.Load(@SearchPath.Text.ToString());
var results = from worker in workersInfo.Element("System").Element("Workers").Elements() where worker.Element("WorkerDepartment").Value == SearchWorkerDepartment.Text.ToString() select worker;
foreach (var result in results)
{
MessageBox.Show(result.Element("WorkerNumber").Value + "\n" + result.Element("WorkerName").Value + "\n" + result.Element("WorkerEmail").Value + "\n" + result.Element("WorkerDepartment").Value);
}
} private void SearchNumberButton_Click(object sender, EventArgs e)
{
XDocument workersInfo = XDocument.Load(@SearchPath.Text.ToString());
var results = from worker in workersInfo.Element("System").Element("Workers").Elements() where int.Parse(worker.Element("WorkerNumber").Value) == int.Parse(SearchWokerNumber.Text.ToString()) select worker;
foreach (var result in results)
{
MessageBox.Show(result.Element("WorkerNumber").Value + "\n" + result.Element("WorkerName").Value + "\n" + result.Element("WorkerEmail").Value + "\n" + result.Element("WorkerDepartment").Value);
}
}
}
}

由于考试时间仓促,只是在功能上满足了这道题的要求,匆匆收尾,还请大家只关注以下三点在实际应用中的实践:

1、使用LinQ查询员工信息;

2、添加员工信息到XML的过程;

3、通过正则表达式验证用户输入信息。

C#中一道关于员工信息系统的题(主要考察LinQ和正则表达式验证)的更多相关文章

  1. C#中一道关于多线程的编程题

    题目的意思是这样的:让两个线程A和B将自己的ID轮番写入一个文件中,每个线程重复十次写入后执行一个回调函数,说“I'm OK”,就这样.我是一名QA,不是开发,出于兴趣报考了公司的C#课程考试,多线程 ...

  2. 一道很经典的 BFS 题

    一道很经典的 BFS 题 想认真的写篇题解. 题目来自:https://www.luogu.org/problemnew/show/P1126 题目描述 机器人移动学会(RMI)现在正尝试用机器人搬运 ...

  3. python--简易员工信息系统编写

    补充内容:eval 将字符串变成变量名locals   看输入的是否是字典中的一个keyfunc.__name____怎么看变量名的数据类型斐波那契数列 li=[1,1] while li[-1]&l ...

  4. ACM_一道耗时间的水题

    一道耗时间的水题 Time Limit: 2000/1000ms (Java/Others) Problem Description: Do you know how to read the phon ...

  5. 一道有趣的for循环题

    一道有趣的for循环题 今天在复习js基础知识时发现了一个for循环的题,第一眼看到直接懵逼了,没想到for循环竟然还可以这样玩?涨姿势了. 题目是这样的 for(i=0, j=0; i<10, ...

  6. SQL-50 将employees表中的所有员工的last_name和first_name通过(')连接起来

    题目描述 将employees表中的所有员工的last_name和first_name通过(')连接起来.CREATE TABLE `employees` (`emp_no` int(11) NOT ...

  7. 【图灵杯 F】一道简单的递推题(矩阵快速幂,乘法模板)

    Description 存在如下递推式: F(n+1)=A1*F(n)+A2*F(n-1)+-+An*F(1) F(n+2)=A1*F(n+1)+A2*F(n)+-+An*F(2) - 求第K项的值对 ...

  8. 检查字符串长度 检查字符串是否为空 用正则表达式验证出版物的ISBN号 用正则表达式验证邮证编码 验证字符串中是否含有汉字

    <?php /** * 常用的正则表达式来验证信息.如:网址 邮箱 手机号等 */ class check { /** * 正则表达式验证email格式 * * @param string $s ...

  9. Python抓取页面中超链接(URL)的三中方法比较(HTMLParser、pyquery、正则表达式) <转>

    Python抓取页面中超链接(URL)的3中方法比较(HTMLParser.pyquery.正则表达式) HTMLParser版: #!/usr/bin/python # -*- coding: UT ...

随机推荐

  1. Unix 网络编程 读书笔记3

    第四章 基本tcp 套接口编程 注意区分AF_XXX 和PF_XXX,AF代表address family, PF代表protocol family. 1 socket 函数 2 connect 函数 ...

  2. Knockout自定义绑定my97datepicker

    /* my97datepicker 时间格式'yyyy-MM-dd HH-mm-ss' */ ko.bindingHandlers.datetimes = { init: function (elem ...

  3. 生成CFree 5.0 注册码

    C-Free 5.0真是一个很棒的编程软件,可今天用着用着却让我注册,下面的注册码分享给大家: 方法一.下载CFree 5.0之后,直接输入以下信息进行注册. 用户名:tianfang电子邮件:qua ...

  4. DevExpress GridControl 动态创建字段及主细关系表过程

    原文地址:http://hi.baidu.com/qdseashore/item/38f1153e9d0143637d034b7a 在做项目中,往往需要在查询基类模板窗口内做主细关系Grid,引用一下 ...

  5. Oracle单实例启动多个实例

    Oracle多实例运行,单个实例就是一个数据库!,一个数据库对应多个实例是RAC Linux建立oracle的实例步骤: 1.在linux服务器的图形界面下,打开一个终端,输入如下的命令: xhost ...

  6. MySQL主从同步的一个小问题解决

    由于历史遗留问题,我们的MySQL主从库的表结构不一致,主库的某个表tableA比从库表tableA少了一个字段. 当尝试在主库上更改表结构时,这行alter语句会随着binlog同步到从库,如果从库 ...

  7. ras api win7 和 win xp 遍历时的不同

    由于在调用RasEnumEntries和RasEnumConnections在xp和win7以上的操作系统中有所不同,所以在win7下正常的代码在xp不一定就可以. 主要是在win7 下可以给参数传N ...

  8. telnet远程登录协议

    什么是Telnet? 对于Telnet的认识,不同的人持有不同的观点,可以把Telnet当成一种通信协议,但是对于入侵者而言,Telnet只是一种远程登录的工具.一旦入侵者与远程主机建立了Telnet ...

  9. Android开发6——布局中的wrap_content和fill_parent以及match_parent

    一.言简意赅 fill_parent 是让控件宽或者高占全屏 wrap_content是让控件的高或宽仅仅把控件里的内容包裹住而不是全屏 二.分别来看  1 fill_parent 设置一个构件的布局 ...

  10. Redis监控技巧总结

    Redis 监控最直接的方法当然就是使用系统提供的 info 命令来做了,你只需要执行下面一条命令,就能获得 Redis 系统的状态报告. redis-cli info 内存使用 如果 Redis 使 ...