Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/excel/26.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
C# 为什么ExportAsFixedFormat中的param paramIgnorePrintAreas不起作用?_C#_Excel - Fatal编程技术网

C# 为什么ExportAsFixedFormat中的param paramIgnorePrintAreas不起作用?

C# 为什么ExportAsFixedFormat中的param paramIgnorePrintAreas不起作用?,c#,excel,C#,Excel,我正在尝试将excel导出到pdf 我用的是C# 我的ExportAsFixedFormat有问题。我的文档有打印区域(在Excel应用程序中设置,如果手动发送打印,则可以工作)。但它在我的程序中不起作用。我将paramparamIgnorePrintAreas设置为false,这没有帮助 public void createXls(){ ApplicationClass excelApplication = new ApplicationClass(); Workbook ex

我正在尝试将
excel
导出到
pdf

我用的是C#

我的
ExportAsFixedFormat
有问题。我的文档有打印区域(在Excel应用程序中设置,如果手动发送打印,则可以工作)。但它在我的程序中不起作用。我将param
paramIgnorePrintAreas
设置为false,这没有帮助

public void createXls(){
    ApplicationClass excelApplication = new ApplicationClass();
    Workbook excelWorkBook = null;
    //Worksheet excelWorksheet = null;
    excelApplication.ScreenUpdating = false;
    excelApplication.Visible = false;

    string paramSourceBookPath = @"C:\Temp\Test.xlsx";
    object paramMissing = Type.Missing;
    string paramExportFilePath = @"C:\Temp\Test.pdf";
    XlFixedFormatType paramExportFormat = XlFixedFormatType.xlTypePDF;
    XlFixedFormatQuality paramExportQuality = XlFixedFormatQuality.xlQualityStandard;
    bool paramOpenAfterPublish = false;
    bool paramIncludeDocProps = true;
    bool paramIgnorePrintAreas = false;
    object paramFromPage = Type.Missing;
    object paramToPage = Type.Missing;
    try
    {
        // Open the source workbook.
        excelWorkBook = excelApplication.Workbooks.Open(paramSourceBookPath,
         false, paramMissing, paramMissing, paramMissing,
         paramMissing, paramMissing, paramMissing, paramMissing,
         paramMissing, paramMissing, paramMissing, paramMissing,
         paramMissing, paramMissing);

    // Save it in the target format.
        if (excelWorkBook != null)
        {
            Worksheet excelWorksheet = (Worksheet) excelWorkBook.ActiveSheet;
            excelWorksheet.ExportAsFixedFormat(paramExportFormat,
             paramExportFilePath, paramExportQuality,
             paramIncludeDocProps, paramIgnorePrintAreas, paramFromPage,
             paramToPage, paramOpenAfterPublish,
             paramMissing);
        }
    } catch (Exception ex)
    {
    //richTextBox1.Text=ex.Message.ToString();
    }
    finally
    {
        // Close the workbook object.
        if (excelWorkBook != null)
        {
            excelWorkBook.Close(false, paramMissing, paramMissing);
            excelWorkBook = null;
        }

        // Quit Excel and release the ApplicationClass object.
        if (excelApplication != null)
        {
            excelApplication.Quit();
            excelApplication = null;
        }

        GC.Collect();
        GC.WaitForPendingFinalizers();
        GC.Collect();
        GC.WaitForPendingFinalizers();
    }
}

仅需在导出之前再次尝试设置打印区域:

excelWorksheet.PageSetup.PrintArea = "Print_Area";
我想,我遇到了一个类似的问题,因为它是Excel的国际版本,这个命令修复了输出格式