最近公司要生成报表,用PHP生成。
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:attachment;filename=test_data.xls");
我百度了下,貌似这个很快能够实现,但是这个文件却是生成在在浏览器下载的地方,
我想把生成的文件生成到指定的目录,这样能否实现呢?
还有,可以往里面插入图片吗?
PHPExcel是英文的,看了半天没看懂。有没有直接生成的例子看啊?
下面我们附上例子:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
/**
+----------------------------------------------------------
* 导入所需的类库 同java的Import
* 本函数有缓存功能
+----------------------------------------------------------
* @param string $class 类库命名空间字符串
* @param string $baseUrl 起始路径
* @param string $ext 导入的文件扩展名
+----------------------------------------------------------
* @return boolen
+----------------------------------------------------------
*/
function import( $class , $baseUrl = '' , $ext = '.class.php' ) {
static $_file = array ();
$class = str_replace ( array ( '.' , '#' ), array ( '/' , '.' ), $class );
if ( '' === $baseUrl && false === strpos ( $class , '/' )) {
// 检查别名导入
return alias_import( $class );
}
if (isset( $_file [ $class . $baseUrl ]))
return true;
else
$_file [ $class . $baseUrl ] = true;
$class_strut = explode ( '/' , $class );
if ( empty ( $baseUrl )) {
if ( '@' == $class_strut [0] || APP_NAME == $class_strut [0]) {
//加载当前项目应用类库
$baseUrl = dirname(LIB_PATH);
$class = substr_replace( $class , basename (LIB_PATH). '/' , 0, strlen ( $class_strut [0]) + 1);
} elseif ( 'think' == strtolower ( $class_strut [0])){ // think 官方基类库
$baseUrl = CORE_PATH;
$class = substr ( $class ,6);
} elseif (in_array( strtolower ( $class_strut [0]), array ( 'org' , 'com' ))) {
// org 第三方公共类库 com 企业公共类库
$baseUrl = LIBRARY_PATH;
} else { // 加载其他项目应用类库
$class = substr_replace( $class , '' , 0, strlen ( $class_strut [0]) + 1);
$baseUrl = APP_PATH . '../' . $class_strut [0] . '/' . basename (LIB_PATH). '/' ;
}
}
if ( substr ( $baseUrl , -1) != '/' )
$baseUrl .= '/' ;
$classfile = $baseUrl . $class . $ext ;
if (! class_exists ( basename ( $class ),false)) {
// 如果类不存在 则导入类库文件
return require_cache( $classfile );
}
}
/**
* 导出EXCEL表格
* @param array $data 数据,二维数组,每条数据一条记录
* @param array $title 每列数据的字段名,一唯数组,必须和数据顺序一致(可省略)
* @param string $filename excel名称
* @param array $field 需要指定导出的数据字段,排序必须和title一致,就是和查出数据的数组key值
*/
function exportExcel( $data = '' , $title = '' , $filename = 'excel' , $field = array ()){
if (! $data || ! is_array ( $data )) return false;
if ( $filename == '' ) $filename = 'excel' ;
if ( $field && is_array ( $field )){ //只要导出指定字段,且按这个顺序导出
$dateNew = array ();
foreach ( $data as $k => $v ){
foreach ( $field as $fkey ){
$dateNew [ $k ][ $fkey ]= $v [ $fkey ];
}
}
$data = $dateNew ;
}
import( "@.ORG.Util.ExcelXml" ); //调用导出excel类
$xls = new ExcelXml( 'UTF-8' , false, 'Sheet1' );
$xls ->addArray( $data , $title );
$xls ->generateXML( $filename );
}
|