當前位置:首頁 » 數據倉庫 » thinkphp輸出資料庫
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

thinkphp輸出資料庫

發布時間: 2022-06-06 08:30:54

『壹』 thinkphp 如何輸出從資料庫讀取出來的html

addslashes(), stripslashes() 一般是入資料庫和出庫的時候使用,以免變數中存儲類似引號這些關鍵詞,這樣的話,本來是內容的部分卻被資料庫識別為標識符來執行,就會引起錯誤.

『貳』 thinkphp怎麼用phpexcel導出數據到excel

(一)導入Excel

第一,在前台html頁面進行上傳文件:如:

復制代碼 代碼如下:

<form method="post" action="php文件" enctype="multipart/form-data">
<h3>導入Excel表:</h3><input type="file" name="file_stu" />

<input type="submit" value="導入" />
</form>

第二,在對應的php文件進行文件的處理

復制代碼 代碼如下:

if (! empty ( $_FILES ['file_stu'] ['name'] ))

{
$tmp_file = $_FILES ['file_stu'] ['tmp_name'];
$file_types = explode ( ".", $_FILES ['file_stu'] ['name'] );
$file_type = $file_types [count ( $file_types ) - 1];

/*判別是不是.xls文件,判別是不是excel文件*/
if (strtolower ( $file_type ) != "xls")
{
$this->error ( '不是Excel文件,重新上傳' );
}

/*設置上傳路徑*/
$savePath = SITE_PATH . '/public/upfile/Excel/';

/*以時間來命名上傳的文件*/
$str = date ( 'Ymdhis' );
$file_name = $str . "." . $file_type;

/*是否上傳成功*/
if (! ( $tmp_file, $savePath . $file_name ))
{
$this->error ( '上傳失敗' );
}

/*

*對上傳的Excel數據進行處理生成編程數據,這個函數會在下面第三步的ExcelToArray類中

注意:這里調用執行了第三步類裡面的read函數,把Excel轉化為數組並返回給$res,再進行資料庫寫入

*/
$res = Service ( 'ExcelToArray' )->read ( $savePath . $file_name );

/*

重要代碼 解決Thinkphp M、D方法不能調用的問題

如果在thinkphp中遇到M 、D方法失效時就加入下面一句代碼

*/
//spl_autoload_register ( array ('Think', 'autoload' ) );

/*對生成的數組進行資料庫的寫入*/
foreach ( $res as $k => $v )
{
if ($k != 0)
{
$data ['uid'] = $v [0];
$data ['password'] = sha1 ( '111111' );
$data ['email'] = $v [1];

$data ['uname'] = $v [3];

$data ['institute'] = $v [4];
$result = M ( 'user' )->add ( $data );
if (! $result)
{
$this->error ( '導入資料庫失敗' );
}
}
}

}

第三:ExcelToArrary類,用來引用phpExcel並處理Excel數據的

復制代碼 代碼如下:

class ExcelToArrary extends Service{

public function __construct() {

/*導入phpExcel核心類 注意 :你的路徑跟我不一樣就不能直接復制*/
include_once('./Excel/PHPExcel.php');
}

/**

* 讀取excel $filename 路徑文件名 $encode 返回數據的編碼 默認為utf8

*以下基本都不要修改

*/

public function read($filename,$encode='utf-8'){

$objReader = PHPExcel_IOFactory::createReader('Excel5');

$objReader->setReadDataOnly(true);

$objPHPExcel = $objReader->load($filename);

$objWorksheet = $objPHPExcel->getActiveSheet();

$highestRow = $objWorksheet->getHighestRow();
$highestColumn = $objWorksheet->getHighestColumn();
$highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn);
$excelData = array();
for ($row = 1; $row <= $highestRow; $row++) {
for ($col = 0; $col < $highestColumnIndex; $col++) {
$excelData[$row][] =(string)$objWorksheet->getCellByColumnAndRow($col, $row)->getValue();
}
}
return $excelData;

}

}

第四,以上就是導入的全部內容,phpExcel包附在最後。

(二)Excel的導出(相對於導入簡單多了)

第一,先查出資料庫裡面要生成Excel的數據,如:

$data= M('User')->findAll(); //查出數據
$name='Excelfile'; //生成的Excel文件文件名
$res=service('ExcelToArrary')->push($data,$name);

第二,ExcelToArrary類,用來引用phpExcel並處理數據的

復制代碼 代碼如下:

class ExcelToArrary extends Service{

public function __construct() {

/*導入phpExcel核心類 注意 :你的路徑跟我不一樣就不能直接復制*/
include_once('./Excel/PHPExcel.php');
}

/* 導出excel函數*/
public function push($data,$name='Excel'){

error_reporting(E_ALL);
date_default_timezone_set('Europe/London');
$objPHPExcel = new PHPExcel();

/*以下是一些設置 ,什麼作者 標題啊之類的*/
$objPHPExcel->getProperties()->setCreator("轉彎的陽光")
->setLastModifiedBy("轉彎的陽光")
->setTitle("數據EXCEL導出")
->setSubject("數據EXCEL導出")
->setDescription("備份數據")
->setKeywords("excel")
->setCategory("result file");
/*以下就是對處理Excel里的數據, 橫著取數據,主要是這一步,其他基本都不要改*/
foreach($data as $k => $v){

$num=$k+1;
$objPHPExcel->setActiveSheetIndex(0)

//Excel的第A列,uid是你查出數組的鍵值,下面以此類推
->setCellValue('A'.$num, $v['uid'])
->setCellValue('B'.$num, $v['email'])
->setCellValue('C'.$num, $v['password'])
}

$objPHPExcel->getActiveSheet()->setTitle('User');
$objPHPExcel->setActiveSheetIndex(0);
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="'.$name.'.xls"');
header('Cache-Control: max-age=0');
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save('php://output');
exit;
}

第三,以上就是導出的全部內容,phpExcel包附在最後。

『叄』 在thinkphp中,怎麼讓從資料庫中查詢到的數據顯示在模板中。

現在有3.2和5.0的版本,以後提問記得要說清楚版本

另外,遇到這種問題,一般先「搜索」
然後看一下官方文檔中有沒有
如果都沒找到,再提問!