sql >> データベース >  >> RDS >> Mysql

mysqldabaseに保存されたdocxファイルのコンテンツをphpのblobタイプとして取得します

    クエリを実行してデータを選択し、結果を変数に入れます。file_put_contentを使用してdocxファイルを取得します。ヘッダーには注意してください。

    それを読むために、プロセスはドキュメントとは異なります。 docxを「解凍」し、その中のxmlファイルを読み取る必要があります。この機能を使用できます:

    <?php
    
    /*Name of the document file*/
    $document = 'filename.docx';
    
    /**Function to extract text*/
    function extracttext($filename) {
        //Check for extension
        $ext = end(explode('.', $filename));
    
        //if its docx file
        if($ext == 'docx')
        $dataFile = "word/document.xml";
        //else it must be odt file
        else
        $dataFile = "content.xml";     
    
        //Create a new ZIP archive object
        $zip = new ZipArchive;
    
        // Open the archive file
        if (true === $zip->open($filename)) {
            // If successful, search for the data file in the archive
            if (($index = $zip->locateName($dataFile)) !== false) {
                // Index found! Now read it to a string
                $text = $zip->getFromIndex($index);
                // Load XML from a string
                // Ignore errors and warnings
                $xml = DOMDocument::loadXML($text, LIBXML_NOENT | LIBXML_XINCLUDE | LIBXML_NOERROR | LIBXML_NOWARNING);
                // Remove XML formatting tags and return the text
                return strip_tags($xml->saveXML());
            }
            //Close the archive file
            $zip->close();
        }
    
        // In case of failure return a message
        return "File not found";
    }
    
    echo extracttext($document);
    ?>
    

    (コードのソース: http ://www.botskool.com/geeks/how-extract-text-docx-or-odt-files-using-php



    1. MySQLで最後の削除コマンドをロールバックするにはどうすればよいですか?

    2. WindowsおよびLinuxでGMTを使用するようにMySQLを設定する方法

    3. MariaDB GROUP_CONCAT()

    4. 名前が特定の文字列で始まるすべてのテーブルを削除します