2016年6月14日 星期二

C# 讀取Excel File並導入SQL

其實一般要用C#讀取EXCEL可以用oledb,但是我發現Github有人撰寫的.net dll更方便於是紀錄一下。
Excel DataReader


public void loadEachXls(string areaTB, int sheet)
{
// Excel 檔案位置
String tmpfilePath = ConfigurationManager.AppSettings["tmpfilePath"];
string filePath = tmpfilePath;

// 你要抓取 Excel檔裡的工作表名稱
//string set = "工作表1";

// 讀取 Excel檔案
FileStream stream = File.Open(filePath, FileMode.Open, FileAccess.Read);

// 創建讀取 Excel檔
IExcelDataReader excelRead = ExcelReaderFactory.CreateOpenXmlReader(stream);

// 將讀取到 Excel檔暫存至內存
DataSet result = excelRead.AsDataSet();

// 獲得 Excel檔的行與列的數目
int columns = result.Tables[sheet].Columns.Count;
int rows = result.Tables[sheet].Rows.Count;

using (SqlConnection cn = new SqlConnection("server=10.10.0.x;Connection Timeout=10;MultipleActiveResultSets=True;database=CMTS;uid=xxxxx;pwd=xxxxxxxxxx"))
{
 cn.Open();
 String deleteMac = "truncate table CMTS.[dbo]." + areaTB;
 SqlCommand cmd = new SqlCommand(deleteMac, cn);
 cmd.ExecuteNonQuery();

 cmd.CommandText = @"insert into CMTS.dbo." + areaTB + " (sid,bsr,node,area,penetration) VALUES (@v1,@v2,@v3,@v4,@v5)";

 // 將資料讀取出來
 for (int i = 1; i < rows; i++)
 {
  for (int j = 0; j < columns; j++)
  {
   string data = result.Tables[sheet].Rows[i][j].ToString();

  }
  cmd.Parameters.AddWithValue("@v1", result.Tables[sheet].Rows[i][0].ToString());
  cmd.Parameters.AddWithValue("@v2", result.Tables[sheet].Rows[i][1].ToString());
  cmd.Parameters.AddWithValue("@v3", result.Tables[sheet].Rows[i][2].ToString());
  cmd.Parameters.AddWithValue("@v4", result.Tables[sheet].Rows[i][3].ToString());
  cmd.Parameters.AddWithValue("@v5", "");
  cmd.ExecuteNonQuery();
  cmd.Parameters.Clear();
 }
 // 讀取完後一定要關閉
 excelRead.Close();
}

}

2016年6月2日 星期四

rrdtool dump 簡單說明

Cacti 的基本工具就是rrdtool,當然MRTG是更基本的東西。 當在往管領域運用時如果要Polling大量的設備或是不同的OID時,如果使用Cacti一個樣板慢慢設定可能會瘋掉,於是就需要使用net-snmp搭配shell自行收集snmp回傳的數值再來畫圖。 然而有時候我們會有分析數據的需求又要重rrd的檔案轉到資料庫或是文字檔,有人會使用rrdfetch來取資料,但實際使用會有一些NaN的狀況,尤其是在流量判斷上會造成斷線的誤判,所以改成使用rrdtool dump會是一個比較好的方式。語法如下。

# rrdtools
 /usr/local/rrdtool/bin/rrdtool dump c7606nm02-G1-09H.rrd > test.xml

2016年6月1日 星期三

SQL DBCC

DBCC 依照微軟官方的解釋為:維護資料庫、索引或檔案群組的作業。但其實當我們進行大量的資料刪除時可以使用DBCC指令釋放空間。 DBCC CHECKDB 的檢查與修復對象是指定的資料庫。 DBCC CHECKTABLE 的檢查與修復對象是指定的資料表或索引檢視表。 i.g. DBCC SHRINKFILE('dbname',10) 其他詳細指令可以參考官方網站:https://msdn.microsoft.com/zh-tw/library/ms188796(v=sql.120).aspx

CentOS Python 3.7 安裝方式

有些開發的程式在python 3.8的檔案套件不相容,例如pymssql,等。 所以如果不建置虛擬環境的話才特意安裝3.7版本的python 安裝流程如下 # 先進行yum套件的update yum update -y # 安裝相依性套件 yum install gcc o...