日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

導(dǎo)出Excel

 修行的嘟嘟 2014-09-15
public ActionResult ExportFeedBack(string beginTime, string endTime)
        {
            Paging page = new Paging { PageIndex = 1, PageSize = 100000000 };
            PagedList<GetCallCentreSearchForFeedBack_Result> list = CustomerBLL.Instance.GetFeedBack(beginTime, endTime, page);
            DataTable dt = ListToDataTable<GetCallCentreSearchForFeedBack_Result>(list);
          
            //開始處理導(dǎo)出EXCEL

            if (list.Count > 0)
            {
                string temp = string.Format("attachment;filename={0}", "FeedBackList.csv");
                Response.ClearHeaders();

                Response.AppendHeader("Content-disposition", temp);

                Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
                Response.ContentType = "application/vnd.ms-excel;charset=gb2312";
                DataSet ds = new DataSet();
                ds.Tables.Add(dt);
                Response.Write(ExportCSV(ds));
                Response.End();
            }
            return View();
        }



/// <summary>
        /// 將泛類型集合List類轉(zhuǎn)換成DataTable
        /// </summary>
        /// <param name="list">泛類型集合</param>
        /// <returns></returns>
        public static DataTable ListToDataTable<T>(List<T> entitys)
        {
            //檢查實(shí)體集合不能為空
            if (entitys == null || entitys.Count < 1)
            {
                throw new Exception("需轉(zhuǎn)換的集合為空");
            }
            //取出第一個(gè)實(shí)體的所有Propertie
            Type entityType = entitys[0].GetType();
            PropertyInfo[] entityProperties = entityType.GetProperties();

            //生成DataTable的structure
            //生產(chǎn)代碼中,應(yīng)將生成的DataTable結(jié)構(gòu)Cache起來,此處略
            DataTable dt = new DataTable();
            for (int i = 0; i < entityProperties.Length; i++)
            {
                //dt.Columns.Add(entityProperties[i].Name, entityProperties[i].PropertyType);
                dt.Columns.Add(entityProperties[i].Name);
            }
            //將所有entity添加到DataTable中
            foreach (object entity in entitys)
            {
                //檢查所有的的實(shí)體都為同一類型
                if (entity.GetType() != entityType)
                {
                    throw new Exception("要轉(zhuǎn)換的集合元素類型不一致");
                }
                object[] entityValues = new object[entityProperties.Length];
                for (int i = 0; i < entityProperties.Length; i++)
                {
                    entityValues[i] = entityProperties[i].GetValue(entity, null);
                }
                dt.Rows.Add(entityValues);
            }
            return dt;
        }

        /// <summary>
        /// 導(dǎo)出Excel.
        /// </summary>
        /// <param name="ds">The ds.</param>
        /// <returns></returns>
        /// 創(chuàng)建者:王宇
        /// 創(chuàng)建日期:9/15/2014 11:42 AM
        /// 修改者:
        /// 修改時(shí)間:
        /// ------------------------------------
        public string ExportCSV(DataSet ds)
        {
            string data = "";
            //data = ds.DataSetName + "\n";

            foreach (DataTable tb in ds.Tables)
            {
                //data += tb.TableName + "\n"; //原來
                data += "問題反饋列表" + "\n";

                //寫出列名
                foreach (DataColumn column in tb.Columns)
                {
                    //data += column.ColumnName + ","; //原來
                    string columnName = GetColumnName(column.ColumnName);
                    if (!string.IsNullOrEmpty(columnName))
                    {
                        data += columnName + ",";
                    }
                }
                data += "\n";

                //寫出數(shù)據(jù)
                foreach (DataRow row in tb.Rows)
                {
                    foreach (DataColumn column in tb.Columns)
                    {
                        //data += row[column].ToString() + ","; //原來
                        string value = GetColumnValue(column.ToString(), row[column].ToString()).Replace("\n", " ");
                        if (value != "TMP")
                        {
                            data += value + ",";
                        }
                    }
                    data += "\n";
                }
                data += "\n";
            }

            return data;
        }

        /// <summary>
        /// 獲取列.
        /// </summary>
        /// <param name="columnName">列名稱.</param>
        /// <returns></returns>
        /// 創(chuàng)建者:王宇
        /// 創(chuàng)建日期:9/15/2014 11:42 AM
        /// 修改者:
        /// 修改時(shí)間:
        /// ------------------------------------
        private string GetColumnName(string columnName)
        {
            string tmp = string.Empty;
            switch (columnName)
            {
                case "EmailOrPhone":
                    tmp = "手機(jī)號/郵箱";
                    break;
                case "Source":
                    tmp = "模板";
                    break;
                case "Path":
                    tmp = "下單來源";
                    break;
                case "CreateDate":
                    tmp = "反饋時(shí)間";
                    break;
                case "Content":
                    tmp = "反饋內(nèi)容";
                    break;
                default:
                    break;
            }
            return tmp;
        }

        /// <summary>
        /// 獲取列值.
        /// </summary>
        /// <param name="columnName">Name of the column.</param>
        /// <param name="value">The value.</param>
        /// <returns></returns>
        /// 創(chuàng)建者:王宇
        /// 創(chuàng)建日期:9/15/2014 11:42 AM
        /// 修改者:
        /// 修改時(shí)間:
        /// ------------------------------------
        private string GetColumnValue(string columnName, string value)
        {
            string tmp = string.Empty;
            switch (columnName)
            {
                case "OrderPath":
                    tmp = "TMP";
                    break;
                case "Name":
                    tmp = "TMP";
                    break;
                default:
                    tmp = value;
                    break;
            }
            return tmp;
        }

    本站是提供個(gè)人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多