我遇到了与这个问题相同的问题:
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 上处理的内容而不是更简单吗?
?
关于c# - 从数据表导出到 excel 时,如何阻止前导 0 被剥离?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/424412/