using System; using System.Collections; using System.Collections.Generic; using System.Data; using System.Text; using System.Windows.Forms; using UAS_LabelMachine.CustomControl; using UAS_LabelMachine.CustomControl.GroupBoxWithBorder; using static System.Windows.Forms.Control; using System.Text.RegularExpressions; using Seagull.BarTender.Print; using Microsoft.CSharp; using System.CodeDom.Compiler; using System.Reflection; using UAS_LabelMachine.Entity; namespace UAS_LabelMachine { class BaseUtil { static string SysDisc; public static string SysDisc1 { get { return SysDisc = Environment.GetEnvironmentVariable("windir").Substring(0, 1); } set { SysDisc = value; } } static int serialnum = 0; static bool FirstCode = false; //生成唯一条码 public static string BarcodeMethod1(string pd_id, string pr_id, string pib_barcode) { if (pib_barcode != "") { if (FirstCode) { serialnum = serialnum + 1; } //第一次的时候去获取数据库查询出来的值 else { serialnum = int.Parse(pib_barcode.Substring(pib_barcode.Length - 4)) + 1; FirstCode = true; } } else { serialnum = serialnum + 1; } string serialcode = serialnum.ToString(); for (int i = serialnum.ToString().Length; i < 4; i++) { serialcode = "0" + serialcode; } return pd_id + "-" + pr_id + "-" + serialcode; } /// /// 筛选DataTable /// /// /// /// public static DataTable filterDataTable(DataTable dt, String condition) { if (dt == null) return new DataTable(); //获取筛选条件中的列名,值 DataRow[] dataRows = dt.Select(condition); DataTable ndt = dt.Clone(); for (int i = 0; i < dataRows.Length; i++) { ndt.Rows.Add(dataRows[i].ItemArray); } return ndt; } public static string DToAny(double DB, int Type) { string H = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"; long D; double B; string tempD = "", tempB = ""; D = (long)DB; B = DB - D; if (D == 0) { tempD = "0"; } while (D != 0) { tempD = H[(((int)D % Type))] + tempD; D = D / Type; } for (int i = 0; i < 7; i++) { if (B == 0) { break; } tempB += H[((int)(B * Type))]; B = B * Type - (int)(B * Type); } if (tempB == "") { return tempD; } else { return tempD + "." + tempB; } } public static DataTable GetExportDataTable(DataGridView dgv) { DataTable dt = ((DataTable)dgv.DataSource).Copy(); for (int i = 0; i < dt.Columns.Count; i++) { for (int j = 0; j < dgv.Columns.Count; j++) { if (dt.Columns[i].ColumnName.ToLower() == dgv.Columns[j].DataPropertyName.ToLower()) { dt.Columns[i].ColumnName = dgv.Columns[j].HeaderText; } } } return dt; } /// /// 通过DataTable的ColumnName和Caption来拼接一条语句 /// /// /// public static string GetGridViewSelectContent(DataGridView d) { StringBuilder selectConetnt = new StringBuilder(); DataTable dt = (DataTable)d.DataSource; if (dt == null) { foreach (DataGridViewColumn dc in d.Columns) { if (dc.DataPropertyName != "" && dc.DataPropertyName != null) { selectConetnt.Append(dc.DataPropertyName + " as " + dc.DataPropertyName + ","); } } } else { foreach (DataColumn dc in dt.Columns) { selectConetnt.Append(dc.Caption + " as " + dc.ColumnName + ","); } } return selectConetnt.Remove(selectConetnt.Length - 1, 1).ToString(); } /// /// 通过字段和其展示的中文值获取查询的内容 /// /// /// /// public static string GetSelectContentByStringArray(string[] field, string[] cnfield) { StringBuilder sb = new StringBuilder(); for (int i = 0; i < field.Length; i++) { sb.Append(field[i] + " as " + cnfield[i] + ","); } //去掉多余的逗号 sb.Remove(sb.Length - 1, 1); return sb.ToString(); } /// /// 传入控件的集合和DataTable,通过判断控件的名称和数据源的列的描述来匹配,支持单层的GroupBox和Panel /// /// /// public static void SetFormValue(ControlCollection collection, DataTable dt) { //DataTable存在数据才进行赋值操作 if (dt.Rows.Count > 0) { for (int i = 0; i < collection.Count; i++) { string controlName = collection[i].Name; //默认给TextBox和Label赋值 if (collection[i] is TextBox || collection[i] is Label || collection[i] is SearchTextBox || collection[i] is CheckBox) { for (int j = 0; j < dt.Columns.Count; j++) { if (controlName.ToUpper() == dt.Columns[j].Caption.ToUpper()) { //字段含有Status内容的才进行转换 if (controlName.ToUpper().Contains("STATUS")) { //对审批状态进行判断 switch (dt.Rows[0][j].ToString().ToUpper()) { case "ENTERING": collection[i].Text = "在录入"; break; case "UNAPPROVED": collection[i].Text = "未批准"; break; case "COMMITED": collection[i].Text = "已提交"; break; case "APPROVE": collection[i].Text = "已批准"; break; case "AUDITED": collection[i].Text = "已审核"; break; case "STARTED": collection[i].Text = "已下发"; break; case "UNCHECK": collection[i].Text = "待检验"; break; case "CHECKING": collection[i].Text = "检验中"; break; default: collection[i].Text = dt.Rows[0][j].ToString(); break; } } else { if (collection[i] is CheckBox) { (collection[i] as CheckBox).Checked = dt.Rows[0][j].ToString() == "-1" ? true : false; } else { collection[i].Text = dt.Rows[0][j].ToString(); } } } } } //对封装在GroupBox的和Panel的控件进行批量赋值 if (collection[i] is GroupBox || collection[i] is Panel || collection[i] is GroupBoxWithBorder) { for (int j = 0; j < collection[i].Controls.Count; j++) { controlName = collection[i].Controls[j].Name; if (collection[i].Controls[j] is TextBox || collection[i].Controls[j] is Label || collection[i].Controls[j] is SearchTextBox) { for (int k = 0; k < dt.Columns.Count; k++) { if (controlName.ToUpper() == dt.Columns[k].Caption.ToUpper()) { collection[i].Controls[j].Text = dt.Rows[0][k].ToString(); } } } } } } } //如果没有记录的话,将dt中含有的列的对应值设置为空 else { for (int i = 0; i < collection.Count; i++) { if (collection[i] is TextBox || collection[i] is Label || collection[i] is SearchTextBox) { for (int j = 0; j < dt.Columns.Count; j++) { if (collection[i].Name.ToUpper() == dt.Columns[j].Caption.ToUpper()) { collection[i].Text = ""; } } } } } } /// /// 获取标签的路径 /// /// /// /// public static string GetLabelUrl(string URL, string LabelName, DateTime time) { //如果是传入的数据是从FTP取的文件 if (URL.Contains("ftp:")) { ftpOperater ftp = new ftpOperater(SystemInf.FTPModel); return ftp.Download(LabelName, time); } else { return URL; } } /// /// 从DGV获取指定的列的数据形式是数组的形式 /// public static ArrayList[] GetColumnDataFromDGV(DataGridView dgv, string[] ColumnName) { ArrayList[] array = new ArrayList[ColumnName.Length]; //实例化和查询参数个数一样的ArrayList for (int i = 0; i < ColumnName.Length; i++) { array[i] = new ArrayList(); } DataTable dt = (DataTable)dgv.DataSource; //如果第一列是否选框的话 if (dgv.Columns[0] is DataGridViewCheckBoxColumn) { for (int i = 0; i < dt.Rows.Count; i++) { if (dgv.Rows[i].Cells[0].FormattedValue.ToString() == "True") { for (int j = 0; j < ColumnName.Length; j++) { array[j].Add(dt.Rows[i][ColumnName[j]]); } } } } //否则直接获取全部的数据 else { for (int i = 0; i < dgv.RowCount; i++) { for (int j = 0; j < ColumnName.Length; j++) { array[j].Add(dt.Rows[i][ColumnName[j]]); } } } return array; } /// /// 通过DataGridView和需要隐藏的字段的数组来对字段进行隐藏 /// /// /// public static void HideField(DataGridView dgv, string[] field) { DataTable dt = (DataTable)dgv.DataSource; foreach (DataColumn dc in dt.Columns) { foreach (string s in field) { if (dc.Caption == s) { dgv.Columns[dc.ColumnName].Visible = false; } } } } /// /// 通过查询的内容获取到字段的描述 /// /// /// public static string[] GetCaptionFromField(string field) { string[] caption = field.Split(','); for (int i = 0; i < caption.Length; i++) { caption[i] = caption[i].Substring(0, caption[i].LastIndexOf("as")).Trim(); } return caption; } /// /// 通过查询的语句获取查询的字段 /// /// /// public static string[] GetField(string field) { string[] fields = field.Split(','); for (int i = 0; i < fields.Length; i++) { fields[i] = fields[i].Substring(fields[i].LastIndexOf("as") + 2, fields[i].Length - fields[i].LastIndexOf("as") - 2).Trim(); } return fields; } /// /// 将DataTable转换为List的键值对 /// /// /// public static List> DataTableToListDictionary(DataTable dt) { List> list = new List>(); foreach (DataRow dr in dt.Rows) { Dictionary dictionary = new Dictionary(); foreach (DataColumn dc in dt.Columns) { dictionary.Add(dc.Caption, dr[dt.Columns.IndexOf(dc)].ToString()); } list.Add(dictionary); } return list; } /// /// 通过描述取DataTable的列名,主要用于从配置中取数据 /// /// /// /// public static string GetColumnNameByCaption(DataTable dt, string caption) { foreach (DataColumn dc in dt.Columns) { if (dc.Caption.ToLower() == caption) { return dc.ColumnName; } } return null; } //用于封装异常,也可以用于错误的提示 public static void ShowError(string errorMessage) { throw new Exception(errorMessage); } /// /// 清除DataTable的结构和数据,清除列结构时需要从最后的一列开始删 /// /// public static void CleanDataTable(DataTable dt) { for (int i = dt.Columns.Count - 1; i >= 0; i--) { dt.Columns.Remove(dt.Columns[i]); } } /// /// 不清楚表结构,只清楚数据 /// /// public static void CleanDataTableData(DataTable dt) { for (int i = dt.Rows.Count - 1; i >= 0; i--) { dt.Rows.Remove(dt.Rows[i]); } } /// /// 获取拼接的字段 /// /// /// public static string GetFieldFromDataTable(DataTable dt) { StringBuilder sb = new StringBuilder(); foreach (DataColumn dc in dt.Columns) { sb.Append(dc.Caption + ","); } return sb.ToString().Substring(sb.ToString().Length - 1, 1); } /// /// 已经定义好的DataGridView绑定数据,operate是用来添加操作列的 /// /// /// /// /// public static void FillDgvWithDataTable(DataGridView dgv, DataTable dt, params DataGridViewImageColumn[] operate) { dgv.AutoGenerateColumns = false; dgv.DataSource = dt; if (operate.Length > 0) { if (dgv.Columns[operate[0].Name] != null) { dgv.Columns.Remove(dgv.Columns[operate[0].Name]); } dgv.Columns.Add(operate[0]); } //纯英文的列不予展示 //Regex regEnglish = new Regex("^[_][a-z]$"); //foreach (DataGridViewColumn dgvc in dgv.Columns) //{ // if (dgvc.HeaderText.IndexOf("_id") > 0) // { // dgvc.Visible = false; // } //} } /// /// 清除DataGridView的数据 /// /// public static void CleanDGVData(DataGridView dgv) { for (int i = dgv.Rows.Count - 1; i >= 0; i--) { dgv.Rows.RemoveAt(i); } } /// /// 清除Form的指定类型的数据 /// /// public static void CleanForm(Form Form) { for (int i = 0; i < Form.Controls.Count; i++) { if (Form.Controls[i] is EnterTextBox || Form.Controls[i] is TextBox || Form.Controls[i] is RichTextBox || Form.Controls[i] is SearchTextBox) Form.Controls[i].Text = ""; if (Form.Controls[i] is DataGridView) CleanDGVData((DataGridView)Form.Controls[i]); } } /// /// 用于给DGV中的Combox列赋静态值 /// /// /// /// /// /// public static void SetDgvColumnComboxData(DataGridViewComboBoxColumn dgvc, string DataPropertyName, string displayField, string valueField, string[] Value) { DataTable dt = new DataTable(); dt.Columns.Add(displayField); dt.Columns.Add(valueField); for (int i = 0; i < Value.Length; i++) { DataGridViewRow row = new DataGridViewRow(); dt.Rows.Add(row); dt.Rows[i][displayField] = Value[i].Split('#')[0]; dt.Rows[i][valueField] = Value[i].Split('#')[1]; } dgvc.DataPropertyName = DataPropertyName; dgvc.DataSource = dt; dgvc.DisplayMember = displayField; dgvc.ValueMember = valueField; } /// /// 用于给DGV中的ComboxCell赋静态值 /// /// /// /// /// public static void SetDGVCellComboxData(DataGridViewComboBoxCell dgvcc, string displayField, string valueField, string[] Value) { DataTable dt = new DataTable(); dt.Columns.Add(displayField); dt.Columns.Add(valueField); for (int i = 0; i < Value.Length; i++) { DataRow dr = dt.NewRow(); dr[displayField] = Value[i].Split('#')[0]; dr[valueField] = Value[i].Split('#')[1]; dt.Rows.Add(dr); } dgvcc.DisplayMember = displayField; dgvcc.ValueMember = valueField; dgvcc.DataSource = dt; } /// /// 用于给DGV中的ComboxCell赋静态值 /// /// /// /// /// public static void SetComboxData(ComboBox dgvcc, string displayField, string valueField, string[] Value) { DataTable dt = new DataTable(); dt.Columns.Add(displayField); dt.Columns.Add(valueField); for (int i = 0; i < Value.Length; i++) { DataRow dr = dt.NewRow(); dr[displayField] = Value[i].Split('#')[0]; dr[valueField] = Value[i].Split('#')[1]; dt.Rows.Add(dr); } dgvcc.DisplayMember = displayField; dgvcc.ValueMember = valueField; dgvcc.DataSource = dt; } /// /// 获取刷选的SQL语句,传入的是TextBox的Control,传入的SQL不带Where条件 /// /// /// /// public static string GetScreenSqlCondition(params Control[] Condition) { string condition = " where "; for (int i = 0; i < Condition.Length; i++) { if (i != Condition.Length - 1) { if (Condition[i] is ComboBox) { condition += "(" + Condition[i].Tag + " like " + "'%" + (Condition[i] as ComboBox).SelectedValue + "%' or " + Condition[i].Tag + " is null) and "; } else { condition += "(" + Condition[i].Tag + " like " + "'%" + Condition[i].Text + "%' or " + Condition[i].Tag + " is null) and "; } } else { if (Condition[i] is ComboBox) { condition += "(" + Condition[i].Tag + " like " + "'%" + (Condition[i] as ComboBox).SelectedValue + "%' or " + Condition[i].Tag + " is null)"; } else { condition += "(" + Condition[i].Tag + " like " + "'%" + Condition[i].Text + "%' or " + Condition[i].Tag + " is null)"; } } } return condition; } public static void CleanDataGridView(DataGridView dgv) { for (int i = dgv.Columns.Count - 1; i >= 0; i--) { dgv.Columns.RemoveAt(i); } } /// /// 取出SQL中的参数占位符 /// /// /// public static string[] GetParamFromSQL(string SQL) { string[] par = SQL.Split(':'); //用来存参数的数组 StringBuilder[] addpar = new StringBuilder[par.Length - 1]; string[] param = new string[par.Length - 1]; for (int i = 0; i < par.Length - 1; i++) { //新建一个char类型的数组用来存储每个字节的变量 char[] c = par[i + 1].ToCharArray(); addpar[i] = new StringBuilder(); for (int j = 0; j < c.Length; j++) { if (c[j] != ' ' && c[j] != ',' && c[j] != ')') { addpar[i].Append(c[j]); } else { break; } } } for (int i = 0; i < par.Length - 1; i++) { param[i] = addpar[i].ToString(); } return param; } public static void SetFormCenter(Form form) { form.StartPosition = FormStartPosition.CenterParent; } /// /// 设置DataGridView的指定列可编辑 /// /// /// public static void SetDataGridViewReadOnly(DataGridView DGV, string[] EditAbleField) { foreach (DataGridViewColumn dc in DGV.Columns) { dc.ReadOnly = true; foreach (string s in EditAbleField) { if (dc.Name.ToLower() == s.ToLower()) { DGV.Columns[dc.Name].ReadOnly = false; } } } } //判断带有CheckBox的DGV是否有项目勾选了 public static DataTable DGVIfChecked(DataGridView dgv) { int CheckCount = 0; DataTable dt = new DataTable(); //第一列是勾选框,排除在循环之外 for (int i = 1; i < dgv.Columns.Count; i++) { dt.Columns.Add(dgv.Columns[i].Name); } for (int i = 0; i < dgv.RowCount; i++) { if (dgv.Rows[i].Cells[0].Value != null) { if (dgv.Rows[i].Cells[0].Value.ToString() == "True") { if (dgv.Rows[i].Tag.ToString() == "SonRow") { DataRow dr = dt.NewRow(); for (int j = 1; j < dgv.ColumnCount; j++) { dr[dgv.Columns[j].Name] = dgv.Rows[i].Cells[j].FormattedValue; } dt.Rows.Add(dr); CheckCount++; } } } } //判断是否勾选了明细 if (CheckCount == 0) { return null; } return dt; } /// /// 设置只允许输入数字 /// /// /// public static void NumOnly(object sender, KeyPressEventArgs e) { if (e.KeyChar != '\b')//这是允许输入退格键 { if ((e.KeyChar < '0') || (e.KeyChar > '9'))//这是允许输入0-9数字 { e.Handled = true; } } } public static Dictionary ToDictionary(string JsonData) { object Data = null; Dictionary Dic = new Dictionary(); if (JsonData.StartsWith("[")) { //如果目标直接就为数组类型,则将会直接输出一个Key为List的List>集合 //使用示例List> ListDic = (List>)Dic["List"]; List> List = new List>(); MatchCollection ListMatch = Regex.Matches(JsonData, @"{[\s\S]+?}");//使用正则表达式匹配出JSON数组 foreach (Match ListItem in ListMatch) { List.Add(ToDictionary(ListItem.ToString()));//递归调用 } Data = List; Dic.Add("List", Data); } else { MatchCollection Match = Regex.Matches(JsonData, @"""(.+?)"": {0,1}(\[[\s\S]+?\]|null|"".+?""|-{0,1}\d*)");//使用正则表达式匹配出JSON数据中的键与值 foreach (Match item in Match) { try { if (item.Groups[2].ToString().StartsWith("[")) { //如果目标是数组,将会输出一个Key为当前Json的List>集合 //使用示例List> ListDic = (List>)Dic["Json中的Key"]; List> List = new List>(); MatchCollection ListMatch = Regex.Matches(item.Groups[2].ToString(), @"{[\s\S]+?}");//使用正则表达式匹配出JSON数组 foreach (Match ListItem in ListMatch) { List.Add(ToDictionary(ListItem.ToString()));//递归调用 } Data = List; } else if (item.Groups[2].ToString().ToLower() == "null") Data = null;//如果数据为null(字符串类型),直接转换成null else Data = item.Groups[2].ToString(); //数据为数字、字符串中的一类,直接写入 Dic.Add(item.Groups[1].ToString(), Data); } catch { } } } return Dic; } public static string AddField(string[] Fields) { string sql = " "; foreach (string field in Fields) { sql += field + ","; } return sql.Substring(0, sql.Length - 1); } public static string GetArrStr(ArrayList arr, string Split) { string Str = ""; for (int i = 0; i < arr.ToArray().Length; i++) { Str += arr.ToArray()[i] + Split; } return Str; } //设置控件不可见 public static void SetControlsVisible(params object[] sender) { foreach (object item in sender) { (item as DataGridViewColumn).Visible = false; } } public static string GetOutBoxSQL(LabelFormatDocument OutFormat, DataTable OutLabelParam, string pi_inoutno, string pib_id, string pib_outboxcode2, bool iCustProdCode, bool iCustPo, bool iDC, bool iLotNo, bool iOrderCode) { StringBuilder sql = new StringBuilder(); sql.Clear(); for (int j = 0; j < OutFormat.SubStrings.Count; j++) { DataRow[] dr1 = OutLabelParam.Select("lp_name='" + OutFormat.SubStrings[j].Name + "'"); if (dr1.Length > 0 && (dr1[0]["lp_valuetype"].ToString() == "字符串" || dr1[0]["lp_valuetype"].ToString() == "text") && dr1[0]["lp_sql"].ToString() != "") { sql.Append(dr1[0]["lp_sql"].ToString() + ","); } } //界面设定的分组条件 string GroupByCondition = ""; if (iCustProdCode) { GroupByCondition += "pd_custprodcode,"; } if (iCustPo) { GroupByCondition += "pd_pocode,"; } if (iDC) { GroupByCondition += "pib_datecode,"; } if (iLotNo) { GroupByCondition += "pib_lotno,"; } if (iOrderCode) { GroupByCondition += "pd_ordercode,"; } if (iCustProdCode || iCustPo || iDC || iLotNo || iOrderCode) { GroupByCondition = " group by " + (GroupByCondition.Substring(0, GroupByCondition.Length - 1)); } sql.Append("max(pib_id),"); return "select " + sql.ToString().Substring(0, sql.Length - 1) + " from prodiobarcode where pib_inoutno = '" + pi_inoutno + "' and pib_outboxcode2 = " + (pib_outboxcode2 == "" ? "0" : pib_outboxcode2) + GroupByCondition; } public static void CustomerInit(string oContent) { if (oContent == ""|| oContent=="null"|| oContent==" ") return; //创建编译环境实例 CSharpCodeProvider objCSharpCodePrivoder = new CSharpCodeProvider(); //UAS_LabelMachine CompilerParameters objCompilerParameters = new CompilerParameters(); objCompilerParameters.ReferencedAssemblies.Add("System.dll"); objCompilerParameters.ReferencedAssemblies.Add("System.Windows.Forms.dll"); objCompilerParameters.GenerateExecutable = false; objCompilerParameters.GenerateInMemory = true; // 4.CompilerResults CompilerResults cr = objCSharpCodePrivoder.CompileAssemblyFromSource(objCompilerParameters, oContent); if (cr.Errors.HasErrors) { foreach (CompilerError err in cr.Errors) { Console.WriteLine(err.ErrorText); } } else { // 通过反射,调用HelloWorld的实例 Assembly objAssembly = cr.CompiledAssembly; object objHelloWorld = objAssembly.CreateInstance("CustInitSpace.CustInitClass", true); MethodInfo objMI = objHelloWorld.GetType().GetMethod("CustInit"); try { Console.WriteLine(objMI.Invoke(objHelloWorld, null)); } catch (Exception ex) { Console.WriteLine(ex.Message); } } } } namespace CustInitSpace { using System; using System.Windows.Forms; public class CustInitClass { public void CustInit() { Form f = Form.ActiveForm; (f.Controls["LabelInf"] as DataGridView).Columns["pib_year"].Visible = false; (f.Controls["LabelInf"] as DataGridView).Columns["pib_month"].Visible = false; (f.Controls["LabelInf"] as DataGridView).Columns["pib_day"].Visible = false; (f.Controls["LabelInf"] as DataGridView).Columns["pib_custoutboxcode"].HeaderText = "芯片号"; } } } }