上一篇主題 :: 下一篇主題 |
發表人 |
內容 |
kib48660
註冊時間: 2003-02-24 文章: 121
第 1 樓
|
發表於: 星期三 十月 21, 2020 3:13 pm 文章主題: 請問在INTERNET上大家報表都是用那套軟體產生 |
|
|
請問在INTERNET上大家報表都是用那套軟體產生 _________________ =========================
人生如霧亦如夢,緣生緣滅還自在,一切隨緣 |
|
回頂端 |
|
|
ckp6250
註冊時間: 2004-07-30 文章: 1645
第 2 樓
|
發表於: 星期一 十月 26, 2020 8:56 pm 文章主題: |
|
|
excel 類的,例如 phpexcel |
|
回頂端 |
|
|
syntech
註冊時間: 2003-05-16 文章: 4225 來自: Taipei,Taiwan
第 3 樓
|
發表於: 星期一 十月 26, 2020 9:32 pm 文章主題: |
|
|
ckp6250 寫到: | excel 類的,例如 phpexcel |
我們一個 PHP 的專案用 phpspreadsheet 做匯出匯入.
PHPEXCEL 據說下課了
----
其實也可以用PHP建立 VFP DCOM 物件,
在VFP DCOM 物件裡用 EXCEL/WORD 做報表
_________________ 如果公司有下列困擾:
1. 找不到便宜,快速,簡易的 生產排程軟體
2. 不知道如何快速排定 採購計劃
3. 成本抓不準,自己算比軟體算有用
4. 想學習系統規劃,想找系統架構的顧問
請聯絡我們,也許我們幫得上忙 |
|
回頂端 |
|
|
ckp6250
註冊時間: 2004-07-30 文章: 1645
第 4 樓
|
發表於: 星期三 十月 28, 2020 11:44 am 文章主題: |
|
|
我本來是想講【phpspreadsheet】
但字母實在太長,只好說是 phpexcel
引言回覆: | 其實也可以用PHP建立 VFP DCOM 物件,
在VFP DCOM 物件裡用 EXCEL/WORD 做報表 |
大大,這個太厚工了啦,包來又包去,
還是 phpspreadsheet 單純。 |
|
回頂端 |
|
|
syntech
註冊時間: 2003-05-16 文章: 4225 來自: Taipei,Taiwan
第 5 樓
|
發表於: 星期三 十月 28, 2020 1:40 pm 文章主題: |
|
|
ckp6250 寫到: |
引言回覆: | 其實也可以用PHP建立 VFP DCOM 物件,
在VFP DCOM 物件裡用 EXCEL/WORD 做報表 |
大大,這個太厚工了啦,包來又包去,
還是 phpspreadsheet 單純。 |
因為就 VFP 論壇
_________________ 如果公司有下列困擾:
1. 找不到便宜,快速,簡易的 生產排程軟體
2. 不知道如何快速排定 採購計劃
3. 成本抓不準,自己算比軟體算有用
4. 想學習系統規劃,想找系統架構的顧問
請聯絡我們,也許我們幫得上忙 |
|
回頂端 |
|
|
CPS0204
註冊時間: 2014-08-24 文章: 451
第 6 樓
|
發表於: 星期四 一月 21, 2021 7:29 pm 文章主題: |
|
|
php+phpspreadsheet 好用
但轉出excel 時, 另存新檔下載excel後,會有亂碼
需在給cell 任何values 前,一定要有下行:
ob_end_clean(); //這行一定要有
$sheet->setCellValue("c1",'this is a book' );
[color=blue] $excel_name = 'test21';
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
header('Content-Disposition: attachment;filename="' . $excel_name . '.xlsx"');
header('Cache-Control: max-age=0'); // 禁止緩存
header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT'); // always modified
$writer = new Xlsx($spreadsheet);
#$writer=IOFactory::createWriter($spreadsheet,'Xlsx'); //用這行會報錯
$writer->save('php://output');[/color] |
|
回頂端 |
|
|
jelinek
註冊時間: 2003-09-29 文章: 8
第 7 樓
|
發表於: 星期一 二月 15, 2021 11:44 pm 文章主題: |
|
|
ActiveVFP只需要一小段程式碼轉excel就達成目的
<%
SET EXACT ON
SET CENTURY ON
Set date to ymd
*sql
oSQL.cSQLCursor = "curOrder"
lsqlwhere = "where orderdate>='"+DTOC(DATE())+"'
oSQL.Execute([SELECT o.* FROM orders o left outer join users u on o.uid=u.id ]+ lsqlwhere +[ order by orderdate])
lcf=ALLTRIM(STR(INT(SECONDS()*1000)))
lcM=[COPY TO ]+oProp.AppStartPath+[Temp\]+lcf+[ type xls]
&lcM
lcNewPath = [http://]+oRequest.ServerVariables("HTTP_HOST") +JustPath(oRequest.ServerVariables("URL"))+[/Temp/]+lcf+[.xls]
oResponse.Redirect(lcNewPath)
RELEASE PROCEDURE oProp.AppStartPath+'prg\dputil'
%> |
|
回頂端 |
|
|
CPS0204
註冊時間: 2014-08-24 文章: 451
第 8 樓
|
發表於: 星期日 八月 29, 2021 2:23 pm 文章主題: |
|
|
PHP 呼叫 VFP 的 COM
由COM內, 拋轉EXCEL更方便操作,老習慣也不需要改!
但com缺點是,生成的xls只能放php server上,無法存在用戶端的pc上
phpspreadsheet 比不上個人的老程式(vfp->xls)
給推一個! |
|
回頂端 |
|
|
chilin
註冊時間: 2003-10-01 文章: 79 來自: Taipei,Taiwan
第 9 樓
|
發表於: 星期五 九月 24, 2021 8:06 pm 文章主題: |
|
|
jelinek 寫到: | ActiveVFP只需要一小段程式碼轉excel就達成目的
<%
SET EXACT ON
SET CENTURY ON
Set date to ymd
*sql
oSQL.cSQLCursor = "curOrder"
lsqlwhere = "where orderdate>='"+DTOC(DATE())+"'
oSQL.Execute([SELECT o.* FROM orders o left outer join users u on o.uid=u.id ]+ lsqlwhere +[ order by orderdate])
lcf=ALLTRIM(STR(INT(SECONDS()*1000)))
lcM=[COPY TO ]+oProp.AppStartPath+[Temp\]+lcf+[ type xls]
&lcM
lcNewPath = [http://]+oRequest.ServerVariables("HTTP_HOST") +JustPath(oRequest.ServerVariables("URL"))+[/Temp/]+lcf+[.xls]
oResponse.Redirect(lcNewPath)
RELEASE PROCEDURE oProp.AppStartPath+'prg\dputil'
%> |
將 cursor 用
copy to file type xl5
筆數限制65535
copy to file type xls
筆數限制更小
如果資料量不大是OK的。 _________________ 一個喜愛Latte的男人 |
|
回頂端 |
|
|
syntech
註冊時間: 2003-05-16 文章: 4225 來自: Taipei,Taiwan
第 10 樓
|
發表於: 星期五 九月 24, 2021 10:18 pm 文章主題: |
|
|
如果你沒用到特殊欄位,或是先把欄位處理一下的話
建議用
COPY TO TYPE FOX2X _________________ 如果公司有下列困擾:
1. 找不到便宜,快速,簡易的 生產排程軟體
2. 不知道如何快速排定 採購計劃
3. 成本抓不準,自己算比軟體算有用
4. 想學習系統規劃,想找系統架構的顧問
請聯絡我們,也許我們幫得上忙 |
|
回頂端 |
|
|
|