一個簡單的下載文件的方法
/**
* 下載文件
*/
public function download($file){
if(!file_exists($file)){
echo "文件不存在";
}
if(!is_readable($file)){
echo "文件不可讀";
}
$file_name = basename($file);//文件名
$file_size = filesize($file);//文件大小
//下載文件的頭
header("Content-type:application/octet-stream");//返回的文件
header("Accept-Range:bytes");//按照字節大小返回
header("Accept-Length:".$file_size);//返回文件大小
header("Content-Disposition:attachment; filename=".$file_name);//客戶端彈出對話框對應的文件名
$content = file_get_contents($file);
echo $content;
die;
}
有關excel導入導出的連接這裏寫鏈接內容
phpExcel類實現下載 policy_info爲一個二維數組
public function exportData()
{
$FSettleBatchPoliciesModel = D('FSettleBatchPolicies');
$batch_id = I('get.batch_id');
$field_display = I('get.field');//用來區分顯示的字段
if (!is_numeric($batch_id)) {
$this->error('批次id錯誤');
}
$policy_info = $FSettleBatchPoliciesModel->getPolicy($batch_id, $field_display);
//導入phpexcel類
header("content-type:text/html;charset=utf-8");
vendor('Excel.PHPExcel');
//創建對象
$excel = new PHPExcel();
//表頭數組
$tableheader = array([
'序號', '保單號', '產品名稱', '保費',
'繳費年期', '繳費方式', '保險期間', '渠道名稱',
'業務員姓名', '投保人', '承保時間', '生效時間'
]);
//設置B列單元格格式爲文本格式
$excel->getActiveSheet()->getStyle("B")->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_TEXT);
$excel->getActiveSheet()->getDefaultColumnDimension()->setWidth(20);
foreach ($policy_info as $k => $v) {
$policy_info[$k]['id'] = $k + 1;
//在保單號前面加上空格
$policy_info[$k]['policy_no'] = " " . $v['policy_no'];
}
$all_policy_array = array_merge($tableheader, $policy_info);
//填充內容
$excel->getActiveSheet()
->fromArray(
$all_policy_array,
NULL, // 忽略的值,不會在excel中顯示
'A1'
);
$file_name = iconv('UTF-8', 'GBK//IGNORE', date('Y-m-d') . '保單數據導出');
//實例化excel輸入類並完成輸出excel文件
$write = new PHPExcel_Writer_Excel5($excel);
//清除緩衝區,避免亂碼
ob_end_clean();
header("Pragma: public");
header("Expires: 0");
header("Cache-Control:must-revalidate, post-check=0, pre-check=0");
header("Content-Type:application/force-download");
header("Content-Type:application/vnd.ms-execl");
header("Content-Type:application/octet-stream");
header("Content-Type:application/download");
header('Content-Disposition:attachment;filename="' . $file_name . '.xls"');
header("Content-Transfer-Encoding:binary");
$write->save('php://output');
}
快捷鍵
- 加粗
Ctrl + B
- 斜體
Ctrl + I
- 引用
Ctrl + Q
- 插入鏈接
Ctrl + L
- 插入代碼
Ctrl + K
- 插入圖片
Ctrl + G
- 提升標題
Ctrl + H
- 有序列表
Ctrl + O
- 無序列表
Ctrl + U
- 橫線
Ctrl + R
- 撤銷
Ctrl + Z
- 重做
Ctrl + Y
Markdown及擴展
Markdown 是一種輕量級標記語言,它允許人們使用易讀易寫的純文本格式編寫文檔,然後轉換成格式豐富的HTML頁面。 —— [ 維基百科 ]
使用簡單的符號標識不同的標題,將某些文字標記爲粗體或者斜體,創建一個鏈接等,詳細語法參考幫助?。
本編輯器支持 Markdown Extra , 擴展了很多好用的功能。具體請參考Github.
表格
Markdown Extra 表格語法:
項目 | 價格 |
---|---|
Computer | $1600 |
Phone | $12 |
Pipe | $1 |
可以使用冒號來定義對齊方式:
項目 | 價格 | 數量 |
---|---|---|
Computer | 1600 元 | 5 |
Phone | 12 元 | 12 |
Pipe | 1 元 | 234 |
定義列表
- Markdown Extra 定義列表語法:
- 項目1
- 項目2
- 定義 A
- 定義 B
- 項目3
- 定義 C
-
定義 D
定義D內容
代碼塊
代碼塊語法遵循標準markdown代碼,例如:
@requires_authorization
def somefunc(param1='', param2=0):
'''A docstring'''
if param1 > param2: # interesting
print 'Greater'
return (param2 - param1 + 1) or None
class SomeClass:
pass
>>> message = '''interpreter
... prompt'''
腳註
生成一個腳註1.
目錄
用 [TOC]
來生成目錄:
數學公式
使用MathJax渲染LaTex 數學公式,詳見math.stackexchange.com.
- 行內公式,數學公式爲:
Γ(n)=(n−1)!∀n∈N 。 - 塊級公式:
更多LaTex語法請參考 這兒.
UML 圖:
可以渲染序列圖:
或者流程圖:
離線寫博客
即使用戶在沒有網絡的情況下,也可以通過本編輯器離線寫博客(直接在曾經使用過的瀏覽器中輸入write.blog.csdn.net/mdeditor即可。Markdown編輯器使用瀏覽器離線存儲將內容保存在本地。
用戶寫博客的過程中,內容實時保存在瀏覽器緩存中,在用戶關閉瀏覽器或者其它異常情況下,內容不會丟失。用戶再次打開瀏覽器時,會顯示上次用戶正在編輯的沒有發表的內容。
博客發表後,本地緩存將被刪除。
用戶可以選擇 把正在寫的博客保存到服務器草稿箱,即使換瀏覽器或者清除緩存,內容也不會丟失。
注意:雖然瀏覽器存儲大部分時候都比較可靠,但爲了您的數據安全,在聯網後,請務必及時發表或者保存到服務器草稿箱。
瀏覽器兼容
- 目前,本編輯器對Chrome瀏覽器支持最爲完整。建議大家使用較新版本的Chrome。
- IE9以下不支持
- IE9,10,11存在以下問題
- 不支持離線功能
- IE9不支持文件導入導出
- IE10不支持拖拽文件導入
- 這裏是 腳註 的 內容. ↩