错误消息“;缺少参数";当我上传excel文件时显示


Error message "Missing argument" showing when i upload excel file

好吧,我有一个php类,它处理word、excel和powerpoint文件,并在加载页面后显示其数据。它完美地显示了word文档数据,但当我使用excel文件时$docObj=new DocxConversion("test.xlsx")然后它向我显示以下错误消息:

我不明白为什么我会收到这些错误信息。有人能告诉我吗?

Warning: Missing argument 1 for DocxConversion::xlsx_to_text(), called in D:'Software 
Installed'xampp'htdocs'evan'toplevel'file.php on line 116 and defined in D:'Software 
Installed'xampp'htdocs'evan'toplevel'file.php on line 58
Notice: Undefined variable: input_file in D:'Software Installed'xampp'htdocs
'evan'toplevel'file.php on line 62
Warning: ZipArchive::open(): Empty string as source in D:'Software Installed'xampp  
'htdocs'evan'toplevel'file.php on line 62

Php类文件

<?php
class DocxConversion{
  private $filename;
  public function __construct($filePath) {
    $this->filename = $filePath;
  }
  private function read_doc() {
    $fileHandle = fopen($this->filename, "r");
    $line = @fread($fileHandle, filesize($this->filename));
    $lines = explode(chr(0x0D),$line);
    $outtext = "";
    foreach($lines as $thisline)
    {
      $pos = strpos($thisline, chr(0x00));
      if (($pos !== FALSE)||(strlen($thisline)==0))
      {
      } else {
        $outtext .= $thisline." ";
      }
    }
    $outtext = preg_replace("/[^a-zA-Z0-9's','.'-'n'r't@'/'_'(')]/","",$outtext);
    return $outtext;
  }
  private function read_docx(){
    $striped_content = '';
    $content = '';
    $zip = zip_open($this->filename);
    if (!$zip || is_numeric($zip)) return false;
    while ($zip_entry = zip_read($zip)) {
      if (zip_entry_open($zip, $zip_entry) == FALSE) continue;
      if (zip_entry_name($zip_entry) != "word/document.xml") continue;
      $content .= zip_entry_read($zip_entry, zip_entry_filesize($zip_entry));
      zip_entry_close($zip_entry);
    }// end while
    zip_close($zip);
    $content = str_replace('</w:r></w:p></w:tc><w:tc>', " ", $content);
    $content = str_replace('</w:r></w:p>', "'r'n", $content);
    $striped_content = strip_tags($content);
    return $striped_content;
  }
  /************************excel sheet************************************/
  function xlsx_to_text($input_file){
    $xml_filename = "xl/sharedStrings.xml"; //content file name
    $zip_handle = new ZipArchive;
    $output_text = "";
    if(true === $zip_handle->open($input_file)){
      if(($xml_index = $zip_handle->locateName($xml_filename)) !== false){
        $xml_datas = $zip_handle->getFromIndex($xml_index);
        $xml_handle = DOMDocument::loadXML($xml_datas, LIBXML_NOENT | LIBXML_XINCLUDE | LIBXML_NOERROR | LIBXML_NOWARNING);
        $output_text = strip_tags($xml_handle->saveXML());
      }else{
        $output_text .="";
      }
      $zip_handle->close();
    }else{
      $output_text .="";
    }
    return $output_text;
  }
  /*************************power point files*****************************/
  function pptx_to_text($input_file){
    $zip_handle = new ZipArchive;
    $output_text = "";
    if(true === $zip_handle->open($input_file)){
      $slide_number = 1; //loop through slide files
      while(($xml_index = $zip_handle->locateName("ppt/slides/slide".$slide_number.".xml")) !== false){
        $xml_datas = $zip_handle->getFromIndex($xml_index);
        $xml_handle = DOMDocument::loadXML($xml_datas, LIBXML_NOENT | LIBXML_XINCLUDE | LIBXML_NOERROR | LIBXML_NOWARNING);
        $output_text .= strip_tags($xml_handle->saveXML());
        $slide_number++;
      }
      if($slide_number == 1){
        $output_text .="";
      }
      $zip_handle->close();
    }else{
      $output_text .="";
    }
    return $output_text;
  }

  public function convertToText() {
    if(isset($this->filename) && !file_exists($this->filename)) {
      return "File Not exists";
    }
    $fileArray = pathinfo($this->filename);
    $file_ext  = $fileArray['extension'];
    if($file_ext == "doc" || $file_ext == "docx" || $file_ext == "xlsx" || $file_ext == "pptx")
    {
      if($file_ext == "doc") {
        return $this->read_doc();
      } elseif($file_ext == "docx") {
        return $this->read_docx();
      } elseif($file_ext == "xlsx") {
        return $this->xlsx_to_text();
      }elseif($file_ext == "pptx") {
        return $this->pptx_to_text();
      }
    } else {
      return "Invalid File Type";
    }
  }
}
//$docObj = new DocxConversion("test.doc");
//$docObj = new DocxConversion("number.docx");
$docObj = new DocxConversion("test.xlsx");
//$docObj = new DocxConversion("test.pptx");
echo $docText= $docObj->convertToText();
?>

Excel文件数据:

Some text some text 
Some text some text 
Some text some text 

这里是这个函数:

function xlsx_to_text($input_file){
    ...
    if(true === $zip_handle->open($input_file)){
        ...
    }else{
        ...
    }
    return $output_text;
}

您在convertToText()函数中调用上述函数如下:

} elseif($file_ext == "xlsx") {
    return $this->xlsx_to_text();
} 

你的xlsx_to_text($input_file)函数需要一个参数,但你在调用它时没有传递一个。我不认为你写类的方式是缩进来传递任何参数。我假设您想在初始化时设置$filename属性的对象上调用该函数。所以,我认为你可以更新你的xlsx_to_text($input_file)功能如下:

function xlsx_to_text(){ // <---------------- Change here.
    ...
    if(true === $zip_handle->open($this->filename)){  // <---------------- Change here.
        ...
    }else{
        ...
    }
    return $output_text;
}

同样,function pptx_to_text($input_file){函数也是如此。