將table匯出為Excel的標準無亂碼寫法

來源:互聯網
上載者:User

標籤:style   blog   http   color   使用   os   io   資料   

匯出為Excel有很多種寫法,對於一些複雜的格式,筆者喜歡在後台先拼成一個<table>,再使用Response輸出。

如果資料中包含中文或者一些特殊字元,可很多不規範的寫法都會導致頁面亂碼,這裡就把一種(筆者認為)最標準的格式帶給大家:

 

Page p = HttpContext.Current.Handler as Page;p.Response.Clear();p.Response.Buffer = true;p.Response.Charset = "UTF-8";p.Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(filename, Encoding.UTF8) + ".xls");p.Response.ContentEncoding = Encoding.UTF8;p.Response.ContentType = "application/vnd.ms-excel";p.EnableViewState = false;p.Response.Write("<html><head><meta http-equiv=‘Content-Type‘ content=‘application/vnd.ms-excel; charset=utf-8‘ /></head>" + text + "</html>");p.Response.End();


以上代碼需注意兩點:

1)Charset/AppendHeader/ContentEncoding都必須統一使用UTF8

2)text裡面如果只有<table>,必須在前後加上<html></html>.為進一步規範,建議用以上代碼格式編寫

 

 

 

好了,現在應該是無論如何你怎麼匯出Excel,也沒有亂碼字元了。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.