情况说明下:做了个简单的学生资助管理系统,信息比较杂,包括学号、姓名、性别、生源地、家庭状况等,当将数据库中的全部数据导出到excel表格中的时候是正常显示的。但是选择一部分数据导出的时候(特定的,某个系或某个班级,比如就导出建筑系的时候)EXCEL文件显示乱码,但是当将乱码文件中的学生单个导出的时候,就没问题了……不知道说明白没有,呵呵,哪位知道或者碰到过这种情况,麻烦指点一下哈,谢谢啦……

解决方案 »

  1.   

    dg.Columns[0].Visible=false;
    Response.Clear(); 
    Response.Buffer= true;
    Response.Charset="GB2312";
    Response.AppendHeader("Content-Disposition","attachment;filename=admin.xls");
    Response.ContentEncoding=System.Text.Encoding.GetEncoding("GB2312");
    //设置输出流为简体中文
    Response.ContentType = "application/ms-excel";
    //设置输出文件类型为excel文件。
    dg.Columns[this.dg.Columns.Count-1].Visible = false;  // *
    dg.Columns[1].Visible = false;  // *this.EnableViewState = false;
    //dg.AllowSorting = false;
    dg.AllowPaging = false;
    //dg.SelectedIndex = -1;
    CreateDataSource();
    System.Globalization.CultureInfo myCItrad = new System.Globalization.CultureInfo("ZH-CN",true);
    System.IO.StringWriter oStringWriter = new System.IO.StringWriter(myCItrad);
    System.Web.UI.HtmlTextWriter oHtmlTextWriter = new System.Web.UI.HtmlTextWriter(oStringWriter);

    dg.RenderControl(oHtmlTextWriter);
    Response.Write(oStringWriter.ToString());
    Response.End();
      

  2.   

    应该是字符串设置Response.Charset = "GB2312"
    和编码设置Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312")出了问题,后来这两处都换成“UTF-8”后,就没有出现这个问题了。