• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            統計

            • 隨筆 - 50
            • 文章 - 42
            • 評論 - 147
            • 引用 - 0

            留言簿(6)

            隨筆分類

            文章分類

            Link

            搜索

            •  

            積分與排名

            • 積分 - 165515
            • 排名 - 159

            最新評論

            閱讀排行榜

            評論排行榜

            my-xls常用方法解析

            MyXls是什么?

                MyXls是用C#開源項目,可以應用于asp.net 或者 .net應用程序上。它根據微軟公開的Excle文檔格式文件(BIFF),以二進制格式直接生成excel文檔,支持Excel versions 97 - 2007. 。這意味著可以不用在服務器上安裝office就能夠以excle格式輸出數據庫中存儲的數據了。這對于許多項目來說都是很有用的。

                目前MyXls已經實現了單元格(cell)的格式設置,包括文本顏色、文本大小、字體、單位格邊框、底色、列寬、行高,合并單元格,多個sheet頁等功能。
                目前MyXls還不支持在excel文檔中生成對象(如、文本框、按鈕等)。MyXls主頁稱即將實現對excel文件的讀取功能,個人認為讀取的功能的用處還不是很多。
                MyXls主頁:http://myxls.in2bits.org/wiki/MainPage.ashx

                下載頁面:http://myxls.in2bits.org/wiki/Downloads.ashx

                盡管網上還有其它的類似開源項目,但我花了幾天的時間認真看過了MyXls的源碼(也修正了其中一個小小的bug),覺得其架構搭建的挺好,所以就以它為基礎吧。希望能進一步完善它的功能!
            (ps:做為C#及.net的初學者,就算在此設定一個目標吧。)


            下載的源碼中包含了幾個簡單的示例,不過實在是太簡單了。讓我不得不仔細分析代碼,才知道怎么使用。
            示例來了:下載MyXls示例文件

             string sheetName = "chc 實例";
                    Worksheet sheet = xls.Workbook.Worksheets.AddNamed(sheetName);//填加名為"chc 實例"的sheet頁
                    Cells cells = sheet.Cells;//Cells實例是sheet頁中單元格(cell)集合
                    //單元格1-base
                    Cell cell = cells.Add(1, 2, "抗");//設定第一行,第二例單元格的值
                    cell.HorizontalAlignment = HorizontalAlignments.Centered;//設定文字居中
                    cell.Font.FontName = "方正舒體";//設定字體
                    cell.Font.Height = 20 * 20;//設定字大小(字體大小是以 1/20 point 為單位的)
                    cell.UseBorder = true;//使用邊框
                    cell.BottomLineStyle = 2;//設定邊框底線為粗線
                    cell.BottomLineColor = Colors.DarkRed;//設定顏色為暗紅

                    //cell的格式還可以定義在一個xf對象中
                    XF cellXF = xls.NewXF();//為xls生成一個XF實例(XF是cell格式對象)
                    cellXF.HorizontalAlignment = HorizontalAlignments.Centered;//設定文字居中
                    cellXF.Font.FontName = "方正舒體";//設定字體
                    cellXF.Font.Height = 20 * 20;//設定字大小(字體大小是以 1/20 point 為單位的)
                    cellXF.UseBorder = true;//使用邊框
                    cellXF.BottomLineStyle = 2;//設定邊框底線為粗線
                    cellXF.BottomLineColor = Colors.DarkRed;//設定顏色為暗紅
                   
                    cell = cells.AddValueCellXF(2, 2,"震", cellXF);//以設定好的格式填加cell

                    cellXF.Font.FontName = "仿宋_GB2312";
                    cell = cells.AddValueCellXF(3, 2, "救", cellXF);//格式可以多次使用

                    ColumnInfo colInfo = new ColumnInfo(xls, sheet);//生成列格式對象
                    //設定colInfo格式的起作用的列為第2列到第5列(列格式為0-base)
                    colInfo.ColumnIndexStart = 1;//起始列為第二列
                    colInfo.ColumnIndexEnd = 5;//終止列為第六列
                    colInfo.Width = 15 * 256;//列的寬度計量單位為 1/256 字符寬
                    sheet.AddColumnInfo(colInfo);//把格式附加到sheet頁上(注:AddColumnInfo方法有點小問題,不給把colInfo對象多次附給sheet頁)
                    colInfo.ColumnIndexEnd = 6;//可以更改列對象的值
                    ColumnInfo colInfo2 = new ColumnInfo(xls, sheet);//通過新生成一個列格式對象,才到能設定其它列寬度
                    colInfo2.ColumnIndexStart = 7;
                    colInfo2.ColumnIndexEnd = 8;
                    colInfo2.Width = 1 * 256;
                    sheet.AddColumnInfo(colInfo2);

                    MergeArea meaA = new MergeArea(1,2,3,4);//一個合并單元格實例(合并第一行、第三例 到 第二行、第四例)
                    sheet.AddMergeArea(meaA);//填加合并單元格
                    cellXF.VerticalAlignment=  VerticalAlignments.Centered;
                    cellXF.Font.Height = 48 * 20;
                    cellXF.Font.Bold = true;
                    cellXF.Pattern = 3;//設定單元格填充風格。如果設定為0,則是純色填充
                    cellXF.PatternBackgroundColor = Colors.DarkRed;//填充的底色
                    cellXF.PatternColor = Colors.DarkGreen;//設定填充線條的顏色
                    cell = cells.Add(1, 3, "災",cellXF);

            posted on 2009-03-04 18:05 pear_li 閱讀(2292) 評論(2)  編輯 收藏 引用 所屬分類: C#/.net

            評論

            # re: my-xls常用方法解析[未登錄] 2009-06-19 13:15 kk

            哪有行高部分的內容啊???????
              回復  更多評論    

            # re: my-xls常用方法解析 2012-08-29 11:32 郭韜

            cells.Add插入字符大于255時,會自動截取,怎么才能完全保留?
              回復  更多評論    
            天天综合久久久网| 无码日韩人妻精品久久蜜桃| 亚洲伊人久久成综合人影院| yellow中文字幕久久网| 久久人妻少妇嫩草AV蜜桃| 久久久久久午夜精品| 久久精品卫校国产小美女| 久久精品亚洲精品国产色婷| 久久免费精品一区二区| 久久综合亚洲鲁鲁五月天| 精品久久8x国产免费观看| 91精品日韩人妻无码久久不卡| 久久久精品国产Sm最大网站| 久久只有这里有精品4| 国内精品久久人妻互换| 久久中文字幕视频、最近更新| 亚洲AV无码一区东京热久久| 久久精品国产亚洲麻豆| 亚洲性久久久影院| 亚洲国产精品久久66| 亚洲精品无码久久久久久| 一本大道久久a久久精品综合| 久久国产免费直播| 久久国产三级无码一区二区| 精品少妇人妻av无码久久| 久久久久久午夜精品| 久久人人爽人人爽人人片AV麻豆 | 久久99热这里只有精品国产| 久久国产乱子精品免费女| 亚洲AV无一区二区三区久久 | 91精品观看91久久久久久| 五月丁香综合激情六月久久| 色综合久久中文字幕综合网| 狠狠色婷婷综合天天久久丁香| 7777精品久久久大香线蕉 | 久久久久无码专区亚洲av| 久久国产精品成人免费| 漂亮人妻被黑人久久精品| 99精品国产综合久久久久五月天 | 久久青青草视频| 亚洲精品无码久久不卡|