Пример #1
0
 public DataTable ListData(string as_symd, string as_eymd)
 {
     return(dao50072.ListData(as_symd, as_eymd));
 }
Пример #2
0
        private bool ManipulateExcel()
        {
            //測試資料查詢日期:2017/12/01
            try {
                txtFromDate.Enabled = false;
                txtToDate.Enabled   = false;

                this.Cursor = Cursors.WaitCursor;
                this.Refresh();
                Thread.Sleep(5);
                lblProcessing.Visible = true;
                ShowMsg("開始轉檔...");
                string rptName, rptId, file;
                int    i;

                /*************************************
                *  ls_rpt_name = 報表名稱
                *  ls_rpt_id = 報表代號
                *  li_ole_col = 欄位位置
                *  ls_param_key = 契約
                *************************************/
                rptName = "STF報價期貨商明細加總日報表";
                rptId   = "50072";
                ShowMsg(rptId + "-" + rptName + " 轉檔中...");

                #region Excel

                //讀取資料
                DataTable dtContent = dao50072.ListData(txtFromDate.FormatValue, txtToDate.FormatValue);
                if (dtContent.Rows.Count == 0)
                {
                    MessageDisplay.Info(string.Format("{0} - {1}, {2} - {3},無任何資料!", txtFromDate.Text, txtToDate.Text, rptId, rptName));
                }
                DataTable dtValidContent = dao50072.ListData_valid(txtFromDate.FormatValue, txtToDate.FormatValue);
                if (dtValidContent.Rows.Count == 0)
                {
                    MessageDisplay.Info(string.Format("{0} - {1}, {2} - {3},無任何資料!", txtFromDate.Text, txtToDate.Text, rptId, "合格報價資料"));
                }

                //複製檔案
                file = PbFunc.wf_copy_file(rptId, rptId);
                if (file == "")
                {
                    return(false);
                }

                //填資料
                Workbook workbook = new Workbook();
                workbook.LoadDocument(file);
                Worksheet worksheet0 = workbook.Worksheets[0];
                Worksheet worksheet2 = workbook.Worksheets[2];

                //50072
                for (i = 0; i < dtContent.Rows.Count; i++)
                {
                    int rowNum = i + 2;

                    worksheet0.Cells[rowNum, 0].Value = dtContent.Rows[i]["mc_date"].AsString();
                    worksheet0.Cells[rowNum, 1].Value = dtContent.Rows[i]["fut_id"].AsString();
                    worksheet0.Cells[rowNum, 2].Value = dtContent.Rows[i]["acctno"].AsString();
                    worksheet0.Cells[rowNum, 3].Value = dtContent.Rows[i]["param_key"].AsString();
                    worksheet0.Cells[rowNum, 4].SetValue(dtContent.Rows[i]["valid_cnt"]);
                    worksheet0.Cells[rowNum, 5].SetValue(dtContent.Rows[i]["valid_time"]);
                    worksheet0.Cells[rowNum, 6].SetValue(dtContent.Rows[i]["valid_result"]);
                    worksheet0.Cells[rowNum, 7].SetValue(dtContent.Rows[i]["qty"]);
                    worksheet0.Cells[rowNum, 8].SetValue(dtContent.Rows[i]["nqty"]);
                    worksheet0.Cells[rowNum, 9].Value = dtContent.Rows[i]["prod_type"].AsString();
                    worksheet0.Cells[rowNum, 10].SetValue(dtContent.Rows[i]["drank"]);
                }

                //合格報價資料
                for (i = 0; i < dtValidContent.Rows.Count; i++)
                {
                    int rowNum = i + 1;

                    worksheet2.Cells[rowNum, 0].Value = dtValidContent.Rows[i]["mc_date"].AsString();
                    worksheet2.Cells[rowNum, 1].Value = dtValidContent.Rows[i]["fut_id"].AsString();
                    worksheet2.Cells[rowNum, 2].Value = dtValidContent.Rows[i]["acctno"].AsString();
                    worksheet2.Cells[rowNum, 3].Value = dtValidContent.Rows[i]["activity_type"].AsString();
                    worksheet2.Cells[rowNum, 4].Value = dtValidContent.Rows[i]["kind_id"].AsString();
                    worksheet2.Cells[rowNum, 5].SetValue(dtValidContent.Rows[i]["valid_time"]);
                    worksheet2.Cells[rowNum, 6].Value = dtValidContent.Rows[i]["prod_type"].AsString();
                    worksheet2.Cells[rowNum, 7].Value = dtValidContent.Rows[i]["market_close"].AsString();
                }

                #endregion

                #region CSV

                /******************
                *  ETF
                ******************/
                //讀取資料
                string    asSymEtf     = txtFromDate.Text.Replace("/", "").Substring(0, 6);
                string    asEymEtf     = txtToDate.Text.Replace("/", "").Substring(0, 6);
                DataTable dtContentETF = dao50072.ListData_etf(asSymEtf, asEymEtf);
                if (dtContentETF.Rows.Count == 0)
                {
                    MessageDisplay.Info(string.Format("{0} - {1}, {2} - {3},無任何資料!", txtFromDate.Text, txtToDate.Text, rptId, "ETF"));
                }
                else
                {
                    //存CSV

                    string etfFileName = Path.Combine(GlobalInfo.DEFAULT_REPORT_DIRECTORY_PATH, "50072_ETF_" + DateTime.Now.ToString("yyyy.MM.dd-HH.mm.ss") + ".csv");
                    File.Create(etfFileName).Close();
                    StringBuilder sbETF = new StringBuilder();

                    IEnumerable <string> etfColumnNames = dtContentETF.Columns.Cast <DataColumn>().
                                                          Select(column => column.ColumnName);
                    sbETF.AppendLine(string.Join(",", etfColumnNames));

                    foreach (DataRow row in dtContentETF.Rows)
                    {
                        IEnumerable <string> fields = row.ItemArray.Select(field =>
                                                                           string.Concat("\"", field.ToString().Replace("\"", "\"\""), "\""));
                        sbETF.AppendLine(string.Join(",", fields));
                    }

                    File.WriteAllText(etfFileName, sbETF.ToString());
                }


                /******************
                *  TXF
                ******************/
                //讀取資料
                string    asSymTxf     = txtFromDate.Text.Replace("/", "").Substring(0, 6);
                string    asEymTxf     = txtToDate.Text.Replace("/", "").Substring(0, 6);
                DataTable dtContentTXF = dao50072.ListData_txf(asSymTxf, asEymTxf);
                if (dtContentTXF.Rows.Count == 0)
                {
                    MessageDisplay.Info(string.Format("{0} - {1}, {2} - {3},無任何資料!", txtFromDate.Text, txtToDate.Text, rptId, "TXF"));
                }
                else
                {
                    //存CSV
                    string txfFileName = Path.Combine(GlobalInfo.DEFAULT_REPORT_DIRECTORY_PATH, "50072_TXF_" + DateTime.Now.ToString("yyyy.MM.dd-HH.mm.ss") + ".csv");
                    File.Create(txfFileName).Close();

                    StringBuilder sbTXF = new StringBuilder();

                    IEnumerable <string> txfColumnNames = dtContentTXF.Columns.Cast <DataColumn>().
                                                          Select(column => column.ColumnName);
                    sbTXF.AppendLine(string.Join(",", txfColumnNames));

                    foreach (DataRow row in dtContentTXF.Rows)
                    {
                        IEnumerable <string> fields = row.ItemArray.Select(field =>
                                                                           string.Concat("\"", field.ToString().Replace("\"", "\"\""), "\""));
                        sbTXF.AppendLine(string.Join(",", fields));
                    }

                    File.WriteAllText(txfFileName, sbTXF.ToString());
                }


                #endregion

                #region MTX 已廢除

                #endregion

                //若所有Sheet皆無資料時,刪除檔案
                if (dtContent.Rows.Count == 0 && dtValidContent.Rows.Count == 0)
                {
                    try {
                        workbook = null;
                        File.Delete(file);
                        //File.Delete(etfFileName);
                        //File.Delete(txfFileName);
                    }
                    catch (Exception) {
                        //
                    }
                    return(false);
                }

                //Excel存檔
                workbook.SaveDocument(file);
                ShowMsg("轉檔成功");
                return(true);
            }
            catch (Exception ex) {
                MessageDisplay.Error("輸出錯誤");
                throw ex;
            }
            finally {
                this.Cursor = Cursors.Arrow;
                this.Refresh();
                Thread.Sleep(5);
                txtFromDate.Enabled = true;
                txtToDate.Enabled   = true;
            }
        }