Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/excel/27.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
通过浏览器将多张图纸导出到Excel_Excel - Fatal编程技术网

通过浏览器将多张图纸导出到Excel

通过浏览器将多张图纸导出到Excel,excel,Excel,我需要将多个数据表导出到客户机上的Excel中,每个表都有自己的工作表。如果只是一张工作表,我会使用Excel/csv内容类型,但我听说过可以表示整个工作簿的XML格式。我不想走包装和.xlsx路线,所以我需要标准的.xls 我们的bug追踪器Gemini以前有一个导出功能,可以生成一个XML文件,Excel会自动将其作为多页工作簿打开,但我找不到它。还有这样的机制吗?我在哪里可以找到该模式?例如,如果您不想创建自己的Excel XML writer库,您可以使用。例如,如果您不想创建自己的Ex

我需要将多个数据表导出到客户机上的Excel中,每个表都有自己的工作表。如果只是一张工作表,我会使用Excel/csv内容类型,但我听说过可以表示整个工作簿的XML格式。我不想走包装和.xlsx路线,所以我需要标准的.xls


我们的bug追踪器Gemini以前有一个导出功能,可以生成一个XML文件,Excel会自动将其作为多页工作簿打开,但我找不到它。还有这样的机制吗?我在哪里可以找到该模式?

例如,如果您不想创建自己的Excel XML writer库,您可以使用。

例如,如果您不想创建自己的Excel XML writer库,您可以使用。

在Excel中,您可以以XML格式保存工作簿。(在Excel2007中称为XML电子表格2003)


这可能会让您开始学习。

在Excel中,您可以将工作簿保存为XML格式。(在Excel2007中称为XML电子表格2003)


这可能会让您开始学习。

在单独的类文件中使用下面的命令,并在page.cs文件中单击“粘贴”按钮以粘贴类似的函数: ExcelHelperNS.ExcelHelper.ToExcel(数据集1,“ExcelFileName”,Page.Response)

在单独的课程中使用此选项,它将起作用。

公共类助手 { //每工作表的行数限制旧版excel verion,excel 2003的行数限制为65536 常数int rowLimit=65000

    private static string getWorkbookTemplate()
    {
        var sb = new StringBuilder(818);
        sb.AppendFormat(@"<?xml version=""1.0""?>{0}", Environment.NewLine);
        sb.AppendFormat(@"<?mso-application progid=""Excel.Sheet""?>{0}", Environment.NewLine);
        sb.AppendFormat(@"<Workbook xmlns=""urn:schemas-microsoft-com:office:spreadsheet""{0}", Environment.NewLine);
        sb.AppendFormat(@" xmlns:o=""urn:schemas-microsoft-com:office:office""{0}", Environment.NewLine);
        sb.AppendFormat(@" xmlns:x=""urn:schemas-microsoft-com:office:excel""{0}", Environment.NewLine);
        sb.AppendFormat(@" xmlns:ss=""urn:schemas-microsoft-com:office:spreadsheet""{0}", Environment.NewLine);
        sb.AppendFormat(@" xmlns:html=""http://www.w3.org/TR/REC-html40"">{0}", Environment.NewLine);
        sb.AppendFormat(@" <Styles>{0}", Environment.NewLine);
        sb.AppendFormat(@"  <Style ss:ID=""Default"" ss:Name=""Normal"">{0}", Environment.NewLine);
        sb.AppendFormat(@"   <Alignment ss:Vertical=""Bottom""/>{0}", Environment.NewLine);
        sb.AppendFormat(@"   <Borders/>{0}", Environment.NewLine);
        sb.AppendFormat(@"   <Font ss:FontName=""Calibri"" x:Family=""Swiss"" ss:Size=""11"" ss:Color=""#000000""/>{0}", Environment.NewLine);
        sb.AppendFormat(@"   <Interior/>{0}", Environment.NewLine);
        sb.AppendFormat(@"   <NumberFormat/>{0}", Environment.NewLine);
        sb.AppendFormat(@"   <Protection/>{0}", Environment.NewLine);
        sb.AppendFormat(@"  </Style>{0}", Environment.NewLine);
        sb.AppendFormat(@"  <Style ss:ID=""s62"">{0}", Environment.NewLine);
        sb.AppendFormat(@"   <Font ss:FontName=""Calibri"" x:Family=""Swiss"" ss:Size=""11"" ss:Color=""#000000""{0}", Environment.NewLine);
        sb.AppendFormat(@"    ss:Bold=""1""/>{0}", Environment.NewLine);
        sb.AppendFormat(@"  </Style>{0}", Environment.NewLine);
        sb.AppendFormat(@"  <Style ss:ID=""s63"">{0}", Environment.NewLine);
        sb.AppendFormat(@"   <NumberFormat ss:Format=""Short Date""/>{0}", Environment.NewLine);
        sb.AppendFormat(@"  </Style>{0}", Environment.NewLine);
        sb.AppendFormat(@" </Styles>{0}", Environment.NewLine);
        sb.Append(@"{0}\r\n</Workbook>");
        return sb.ToString();
    }

    private static string replaceXmlChar(string input)
    {
        input = input.Replace("&", "&amp");
        input = input.Replace("<", "&lt;");
        input = input.Replace(">", "&gt;");
        input = input.Replace("\"", "&quot;");
        input = input.Replace("'", "&apos;");
        return input;
    }

    private static string getCell(Type type, object cellData)
    {
        var data = (cellData is DBNull) ? "" : cellData;
        if (type.Name.Contains("Int") || type.Name.Contains("Double") || type.Name.Contains("Decimal")) return string.Format("<Cell><Data ss:Type=\"Number\">{0}</Data></Cell>", data);
        if (type.Name.Contains("Date") && data.ToString() != string.Empty)
        {
            return string.Format("<Cell ss:StyleID=\"s63\"><Data ss:Type=\"DateTime\">{0}</Data></Cell>", Convert.ToDateTime(data).ToString("yyyy-MM-dd"));
        }
        return string.Format("<Cell><Data ss:Type=\"String\">{0}</Data></Cell>", replaceXmlChar(data.ToString()));
    }
    private static string getWorksheets(DataSet source)
    {
        var sw = new StringWriter();
        if (source == null || source.Tables.Count == 0)
        {
            sw.Write("<Worksheet ss:Name=\"Sheet1\">\r\n<Table>\r\n<Row><Cell><Data ss:Type=\"String\"></Data></Cell></Row>\r\n</Table>\r\n</Worksheet>");
            return sw.ToString();
        }
        foreach (DataTable dt in source.Tables)
        {
            if (dt.Rows.Count == 0)
                sw.Write("<Worksheet ss:Name=\"" + replaceXmlChar(dt.TableName) + "\">\r\n<Table>\r\n<Row><Cell  ss:StyleID=\"s62\"><Data ss:Type=\"String\"></Data></Cell></Row>\r\n</Table>\r\n</Worksheet>");
            else
            {
                //write each row data                
                var sheetCount = 0;
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    if ((i % rowLimit) == 0)
                    {
                        //add close tags for previous sheet of the same data table
                        if ((i / rowLimit) > sheetCount)
                        {
                            sw.Write("\r\n</Table>\r\n</Worksheet>");
                            sheetCount = (i / rowLimit);
                        }
                        sw.Write("\r\n<Worksheet ss:Name=\"" + replaceXmlChar(dt.TableName) +
                                 (((i / rowLimit) == 0) ? "" : Convert.ToString(i / rowLimit)) + "\">\r\n<Table>");
                        //write column name row
                        sw.Write("\r\n<Row>");
                        foreach (DataColumn dc in dt.Columns)
                            sw.Write(string.Format("<Cell ss:StyleID=\"s62\"><Data ss:Type=\"String\">{0}</Data></Cell>", replaceXmlChar(dc.ColumnName)));
                        sw.Write("</Row>");
                    }
                    sw.Write("\r\n<Row>");
                    foreach (DataColumn dc in dt.Columns)
                        sw.Write(getCell(dc.DataType, dt.Rows[i][dc.ColumnName]));
                    sw.Write("</Row>");
                }
                sw.Write("\r\n</Table>\r\n</Worksheet>");
            }
        }

        return sw.ToString();
    }
    public static string GetExcelXml(DataTable dtInput, string filename)
    {
        var excelTemplate = getWorkbookTemplate();
        var ds = new DataSet();
        ds.Tables.Add(dtInput.Copy());
        var worksheets = getWorksheets(ds);
        var excelXml = string.Format(excelTemplate, worksheets);
        return excelXml;
    }

    public static string GetExcelXml(DataSet dsInput, string filename)
    {
        var excelTemplate = getWorkbookTemplate();
        var worksheets = getWorksheets(dsInput);
        var excelXml = string.Format(excelTemplate, worksheets);
        return excelXml;
    }

    public static void ToExcel(DataSet dsInput, string filename, HttpResponse response)
    {
        var excelXml = GetExcelXml(dsInput, filename);
        response.Clear();
        response.AppendHeader("Content-Type", "application/vnd.ms-excel");
        response.AppendHeader("Content-disposition", "attachment; filename=" + filename);
        response.Write(excelXml);
        response.Flush();
        response.End();
    }

    public static void ToExcel(DataTable dtInput, string filename, HttpResponse response)
    {
        var ds = new DataSet();
        ds.Tables.Add(dtInput.Copy());
        ToExcel(ds, filename, response);
    }
}
私有静态字符串getWorkbookTemplate()
{
var sb=新的StringBuilder(818);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.AppendFormat(@“{0}”,Environment.NewLine);
sb.Append(@“{0}\r\n”);
使某人返回字符串();
}
私有静态字符串replaceXmlChar(字符串输入)
{
输入=输入。替换(“&”、“&”);
输入=输入。替换(“,”);
输入=输入。替换(“\”,“”);
输入=输入。替换(“”,“&apos;”);
返回输入;
}
私有静态字符串getCell(类型,对象cellData)
{
var data=(cellData为DBNull)?“”:cellData;
if(type.Name.Contains(“Int”)| | type.Name.Contains(“Double”)| | type.Name.Contains(“Decimal”))返回string.Format(“{0}”,数据);
if(type.Name.Contains(“Date”)&&data.ToString()!=string.Empty)
{
返回string.Format(“{0}”,Convert.ToDateTime(data.ToString)(“yyyy-MM-dd”);
}
返回string.Format(“{0}”,replaceXmlChar(data.ToString());
}
私有静态字符串getWorksheets(数据集源)
{
var sw=新的StringWriter();
if(source==null | | source.Tables.Count==0)
{
sw.Write(“\r\n\r\n\r\n\r\n”);
返回sw.ToString();
}
foreach(source.Tables中的DataTable dt)
{
如果(dt.Rows.Count==0)
sw.Write(“\r\n\r\n\r\n\r\n”);
其他的
{
//写入每行数据
var-sheetCount=0;
对于(int i=0;i张数)
{
sw.Write(“\r\n\r\n”);
sheetCount=(i/rowLimit);
}
sw.Write(“\r\n\r\n”);
//写入列名行
sw.Write(“\r\n”);
foreach(数据列dc在dt.列中)
Write(string.Format(“{0}”,replaceXmlChar(dc.ColumnName));
sw.写(“”);
}
sw.Write(“\r\n”);
foreach(数据列dc在dt.列中)
sw.Write(getCell(dc.DataType,dt.Rows[i][dc.ColumnName]);
sw.写(“”);
}
sw.Write(“\r\n\r\n”);
}
}
返回sw.ToString();
}
公共静态字符串GetExcelXml(数据表dtInput,字符串文件名)
{
var excelTemplate=getWorkbookTemplate();
var ds=新数据集();
Add(dtInput.Copy());
var工作表=获取工作表(ds);
var excelXml=string.Format(excelTemplate,工作表);
返回excelXml;
}
公共静态字符串GetExcelXml(数据集dsInput,字符串文件名)
{
var excelTemplate=getWorkbookTemplate();
var工作表=获取工作表(dsInput);
var excelXml=string.Format(excelTemplate,工作表);
返回excelXml;
}
publicstaticvoidtoexcel(数据集dsInput、字符串文件名、HttpResponse响应)
{
var excelXml=GetExcelXml(dsInput,文件名);
response.Clear();
答复.附件