using System;
using System.Windows.Forms;
using System.Text;
using System.Data;
using System.Reflection;
using System.Xml;
using System.Net;
using System.Net.Sockets;
using System.IO;
using System.IO.Ports;
using System.Collections;
using System.Collections.Generic;
using System.Data.OleDb;
using System.Data.SqlTypes;
using System.Data.SqlClient;
using System.Drawing;
using System.Text.RegularExpressions;
/* OrBit-Script指令碼
* 作 者:
* 功能描述:
* 版 本 號:
* 釋出日期:
* 最後修改:
*/
namespace ScriptProj
{
public class OrBitClass
{
public string ExcelFileName = "";
//上傳行數
public string FileCount = "";
public List<string> nbrs = new List<string>();
//MessageBox 結果
public DialogResult dialogResult;
/// <summary>
/// MES事務外掛介面全域性物件,它提供了MES事務物件的所有的介面屬性與介面方法
/// </summary>
public OrBitScript.OrBitAPI Scripter = new OrBitScript.OrBitAPI();
/// <summary>
/// 指令碼物件例項化時載入時的方法
/// </summary>
public void ScriptLoad()
{
//to do..
}
/// <summary>
/// 指令碼在退出前的詢問方法
/// </summary>
/// <returns>True則退出,False則取消退出</returns>
public bool ScriptClosing()
{
//to do..
return true;
}
/// <summary>
/// MES事務物件在關閉時解除安裝此指令碼物件的方法
/// </summary>
public void ScriptUnLoad()
{
//to do..
}
/// <summary>
/// Winsocket訊息接受方法
/// </summary>
/// <param name="MsgString">訊息的內容</param>
public void WinsocketMessage(string MsgString)
{
//to do..
}
/// <summary>
/// MES事務外掛Tab頁選中時的指令碼物件執行的方法
/// </summary>
public void TabActive()
{
//to do..
}
/// <summary>
/// 容器中按鈕觸發時的通用檢查前置事件
/// </summary>
/// <param name="ButtonName">按鈕名</param>
/// <returns>True表示繼續,False表示退回</returns>
public bool ButtonClickBefore(string ButtonName)
{
//to do..
return true;
}
/// <summary>
/// 容器中按鈕通用觸發事件
/// </summary>
/// <param name="ButtonName">按鈕名</param>
public void ButtonClick(string ButtonName)
{
if (ButtonName=="ImportData")
{
OpenFileDialog ofd=new OpenFileDialog();
ofd.FilterIndex=1;
ofd.Filter="文件(*.xls;*.xlsx)|*.xls;*.xlsx";
dialogResult=ofd.ShowDialog();
string str=ofd.FileName.ToString();
ExcelFileName=str.Substring(str.LastIndexOf(@"\"));
//MessageBox.Show(ExcelFileName);
// if(dialogResult==DialogResult.OK)
// {
// Scripter.SetParameterValue("FilePath",ofd.FileName);
// }
DataSet ds = new DataSet();
try
{
// //填充資料
// cmd.Fill(ds);
// //關閉連線
// conn.Close();
ds=xsldata(ofd.FileName);
ds.Tables[0].TableName="Table";
// Write to xml
//ds.WriteXml("D:\\Test.xml");
//MessageBox.Show(ds.GetXml());
//Scripter.SetParameterValue("test",ds.GetXml());
Scripter.SetParameterValue("XMLA",ds.GetXml());
//執行儲存過程
string sql="exec Txn_GX_ImportInspectionDataDoMethod @XMLA='"+ds.GetXml()+"'" ;
//MessageBox.Show("AA"+ds.GetXml());
Scripter.GetSqlDataSet(sql);
//MessageBox.Show("BB"+ds.GetXml());
string XMLA = Scripter.GetParameterValue("XMLA");
if((!nbrs.Contains(XMLA)) && XMLA != "")
{
Scripter.RunMethod("LoadXML");
MessageBox.Show("資料匯入成功");
}
}
catch
{
return ;
}
//
}
//to do..
}
private DataSet xsldata(string filepath)
{
try
{
string st = ExcelFileName.Substring(ExcelFileName.LastIndexOf(".") + 1);
string strForRe = "";
if (st == "xls")
{
strForRe = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source= "
+ filepath + ";Extended Properties='Excel 8.0;HDR=NO;IMEX=1'";
}
else if (st == "xlsx")
{
strForRe = "Provider=Microsoft.Ace.OLEDB.12.0;Data Source= "
+ filepath + ";Extended Properties='Excel 8.0;HDR=NO;IMEX=1'";
}
OleDbConnection connection =
new OleDbConnection(strForRe);
connection.Open();
string tableName = "";
DataTable table = connection.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables, null);
tableName = table.Rows[0]["Table_Name"].ToString();
string str2 = "SELECT * FROM [" + tableName + "]";
OleDbDataAdapter adapter = new OleDbDataAdapter(str2, connection);
DataSet dataSet = new DataSet();
adapter.Fill(dataSet, "[" + tableName + "]");
connection.Close();
return dataSet;
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
return null;
}
}
/// <summary>
/// 容器中按鈕觸發時的通用檢查後置事件
/// </summary>
/// <param name="ButtonName">按鈕名</param>
/// <param name="SPResult">儲存過程執行的結果值</param>
/// <param name="SPMessage">儲存過程執行的返回訊息</param>
public void ButtonClickAfter(string ButtonName,bool SPResult,string SPMessage)
{
//to do..
}
/// <summary>
/// 容器中網格或下拉選單選中某行時的觸發事件
/// </summary>
/// <param name="ParameterName">物件引數名</param>
/// <param name="CellA">選中行第一列的值</param>
/// <param name="CellB">選中行第二列的值</param>
public void RowSelected(string ParameterName, string CellA, string CellB)
{
//to do..
}
/// <summary>
/// 容器中可輸入控制元件獲取游標焦點後觸發的事件
/// </summary>
/// <param name="ParameterName">物件引數名</param>
public void ParameterEnter(string ParameterName)
{
//to do..
}
/// <summary>
/// 容器中可輸入控制元件按回車後觸發的事件
/// </summary>
/// <param name="ParameterName">物件引數名</param>
/// <param name="ParameterValue">輸入值</param>
/// <returns>True跳到下一個控制元件,False表示留在原控制元件中</returns>
public bool EnterPressed(string ParameterName, string ParameterValue)
{
//to do..
return true;
}
/// <summary>
/// 批號掃描成功後觸發的事件
/// </summary>
public void LotSNScanned(string LotSN)
{
//to do..
}
/// <summary>
/// 動態事務批號傳送前觸發的事件
/// </summary>
/// <returns>True允許執行Move,False終止</returns>
public bool LotMoveBefore(string LotId)
{
//to do..
return true;
}
/// <summary>
/// 動態事務批號傳送後觸發的事件
/// </summary>
public void LotMoved(string LotId)
{
//to do..
}
/// <summary>
/// 復位按鈕觸發的事件
/// </summary>
public void LotReset()
{
//to do..
}
}
}
匯入excel檔案
相關文章
- Java POI匯入Excel檔案JavaExcel
- EasyExcel完成excel檔案的匯入匯出Excel
- mysql匯入文字或excel檔案MySqlExcel
- 如何使用JavaScript匯入和匯出Excel檔案JavaScriptExcel
- ASP.NET MVC 匯入Excel檔案ASP.NETMVCExcel
- office for Mac Excel匯入csv檔案亂碼MacExcel
- MATLAB匯入txt和excel檔案技巧彙總:批量匯入、單個匯入MatlabExcel
- java匯出Excel檔案JavaExcel
- php讀取excel檔案資料的匯入和匯出PHPExcel
- MySQL匯入匯出檔案檔案MySql
- Net.Core匯入EXCel檔案裡的資料Excel
- java程式碼實現excel檔案資料匯入JavaExcel
- Java 匯入資料到Excel並提供檔案下載介面JavaExcel
- 利用xlrd模組在Django專案中實現Excel檔案匯入DjangoExcel
- POI匯出excel檔案加水印Excel
- Java 通過Xml匯出Excel檔案,Java Excel 匯出工具類,Java匯出Excel工具類JavaXMLExcel
- svn匯入檔案
- Excel非常快的匯入文字檔案靈活技術Excel
- linux_shell_awk 處理 文字檔案 並匯入excelLinuxExcel
- 將Excel檔案匯入資料庫(POI+Excel+MySQL+jsp頁面匯入)第一次優化Excel資料庫MySqlJS優化
- vue excel匯入匯出VueExcel
- Laravel-admin 匯出excel檔案LaravelExcel
- 【Mysql】匯出資料到excel檔案中MySqlExcel
- vue3 匯出為Excel檔案VueExcel
- (十一)Electron 匯入匯出檔案
- mysql 匯入匯出 sql檔案MySql
- MySQL匯入匯出平面檔案MySql
- sqlserver匯入匯出文字檔案SQLServer
- excel匯入工具Excel
- 原生PHP網頁匯出和匯入excel檔案例項PHP網頁Excel
- 前端必讀:如何在 JavaScript 中使用 SpreadJS 匯入和匯出 Excel 檔案前端JavaScriptJSExcel
- Mysql匯入csv檔案MySql
- Mysql匯入本地檔案MySql
- vfp匯入文字檔案
- oracle匯入dmp檔案Oracle
- easyExcel分批匯入檔案Excel
- Angular Excel 匯入與匯出AngularExcel
- Excel匯入匯出神器(Java)ExcelJava