c# - 从数据表导出到 excel 时,如何阻止前导 0 被剥离?

标签 c# asp.net excel

我遇到了与这个问题相同的问题:

How do you prevent leading zeros from being stripped when importing an excel doc using c#

但我不确定这是否是我的方案的最佳解决方案。这是我用来进行导出的代码。有谁知道我可以改变什么来防止前导 0 被剥离?

private static void Export_with_XSLT_Web(DataSet dsExport, 
                                         string[] sHeaders, 
                                         string[] sFileds, 
                                         ExportFormat FormatType, 
                                         string FileName)
{

        HttpContext.Current.Response.Clear();
        HttpContext.Current.Response.Buffer = true;

        HttpContext.Current.Response.ContentType = "application/vnd.ms-excel";
        HttpContext.Current.Response.AppendHeader("content-disposition", 
                                                  "attachment; 
                                                  filename=" + FileName);
        }

        // XSLT to use for transforming this dataset.                       
        MemoryStream stream = new MemoryStream();
        XmlTextWriter writer = new XmlTextWriter(stream, Encoding.UTF8);

        CreateStylesheet(writer, sHeaders, sFileds, FormatType);
        writer.Flush();
        stream.Seek(0, SeekOrigin.Begin);

        XmlDataDocument xmlDoc = new XmlDataDocument(dsExport);
        XslTransform xslTran = new XslTransform();
        xslTran.Load(new XmlTextReader(stream), null, null);

        using(StringWriter sw = new StringWriter())
        {
            xslTran.Transform(xmlDoc, null, sw, null);

            HttpContext.Current.Response.Write(sw.ToString());                
            writer.Close();
            stream.Close();
            HttpContext.Current.Response.End();
        }
    }
}

这是创建样式表的方法,这里有什么我可以更改以将部分或所有字段作为文本引入的方法。
private static void CreateStylesheet(XmlTextWriter writer, 
                                     string[] sHeaders, 
                                     string[] sFileds, 
                                     ExportFormat FormatType)
{
    try
    {
        // xsl:stylesheet
        string ns = "http://www.w3.org/1999/XSL/Transform";
        writer.Formatting = Formatting.Indented;
        writer.WriteStartDocument();
        writer.WriteStartElement("xsl", "stylesheet", ns);
        writer.WriteAttributeString("version", "1.0");
        writer.WriteStartElement("xsl:output");
        writer.WriteAttributeString("method", "text");
        writer.WriteAttributeString("version", "4.0");
        writer.WriteEndElement();

        // xsl-template
        writer.WriteStartElement("xsl:template");
        writer.WriteAttributeString("match", "/");

        // xsl:value-of for headers
        for(int i = 0; i < sHeaders.Length; i++)
        {
            writer.WriteString("\"");
            writer.WriteStartElement("xsl:value-of");
            writer.WriteAttributeString("select", "'" + sHeaders[i] + "'");
            writer.WriteEndElement(); // xsl:value-of
            writer.WriteString("\"");
        }

        // xsl:for-each
        writer.WriteStartElement("xsl:for-each");
        writer.WriteAttributeString("select", "Export/Values");
        writer.WriteString("\r\n");

        // xsl:value-of for data fields
        for(int i = 0; i < sFileds.Length; i++)
        {
            writer.WriteString("\"");
            writer.WriteStartElement("xsl:value-of");
            writer.WriteAttributeString("select", sFileds[i]);
            writer.WriteEndElement(); // xsl:value-of
            writer.WriteString("\"");
        }

        writer.WriteEndElement(); // xsl:for-each
        writer.WriteEndElement(); // xsl-template
        writer.WriteEndElement(); // xsl:stylesheet
        writer.WriteEndDocument();
    }
    catch(Exception Ex)
    {
        throw Ex;
    }
}

最佳答案

我不知道您的 XSL 转换的输出:我假设它是 Excel 的 xml 格式。
试图扭转这个过程,我在 Excel 工作表中写了三个数字 (007):一次作为数字,一次作为文本,一次作为数字,但格式化为显示用零填充的 3 位数字。然后我将它保存为xml并查看它。这是片段:

<Row>
    <Cell><Data ss:Type="Number">7</Data></Cell>
</Row>
<Row>
    <Cell><Data ss:Type="String" x:Ticked="1">007</Data></Cell>
</Row>
<Row>
    <Cell ss:StyleID="s22"><Data ss:Type="Number">7</Data></Cell>
</Row>

我不是在复制这种风格,但你可以轻松做到。

编辑:一如既往,谷歌是你的 friend (也是我的 friend ;-)):http://www.creativyst.com/Doc/Articles/CSV/CSV01.htm#CSVAndExcel .

编辑(2):我认为链接就足够了。文章说(如果您确定目标是 Excel)您可以使用 Excel 特定的 CSV 语法。因此,在您的情况下并查看您的代码,我认为您应该插入缺少的逗号并更改开头
writer.WriteString("\"");

进入
writer.WriteString("=\"");

请注意我没有尝试。

出于好奇,只有一个问题:仅输出您需要在 DataSet 上处理的内容而不是更简单吗?
  • 将其转换为 XML
  • 生成临时 XSL
  • 执行 XSL 转换
  • 将结果复制到响应流

  • ?

    关于c# - 从数据表导出到 excel 时,如何阻止前导 0 被剥离?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/424412/

    相关文章:

    asp.net - Visual basic以编程方式将用户名和密码传递给https url,使网络浏览器显示网页并从网页下载

    c# - 使用 EPPlus 合并单元格?

    Excel VBA 添加自动筛选器(如果不存在)

    c# - 将 list<int> 转换为 int[]

    C# 获取打开的Word文档列表

    c# - 在 C# 中使用 XSLT 转换 XML

    c# - 不能使用 columnwidth excel 属性

    c# - ASP.NET - App_Code - 在同一文件夹中混合 VB 和 C#

    c# - 如何强制 XDocument 在声明行中输出 "UTF-8"?

    c# - DetailsView 的事件 "ItemUpdating"中的 OldValues 集合始终为空