在WEB页面上将EXCEL文件导入、导出到数据库中

  笔者由于工作需要,在OA系统中,需要将EXCEL文件的内容导入到数据库中,同时还需要将数据库中的内容导出到EXCEL文件中。笔者的OA是用PHP开发的,并且应用在WEB页面上,所以直接用PHP处理难度比较大。经过研究,笔者用DELPHI开发了一个ACTIVEX控件,来处理EXCEL文件的数据,然后将数据提交到服务器上,再保存到数据库中,轻松的实现了EXCEL文件数据的导入。导出没有用ACTIVEX控件,直接用PHP处理。方法是将数据直接生成CSV文件,因为CSV是逗号分隔的文本文件,并且可以直接用EXCEL打开处理,所以可以满足要求。   下面将实现的方法介绍一下。导入的页面代码: "人员编号", "FIELDNAME"=>"STUFFID", "FIELDTYPE"=>"A"), array ("CAPTION"=>"开始日期", "FIELDNAME"=>"BEGINDATE", "FIELDTYPE"=>"A"), array ("CAPTION"=>"结束日期", "FIELDNAME"=>"ENDDATE", "FIELDTYPE"=>"A"), array ("CAPTION"=>"合同内容", "FIELDNAME"=>"CONTRACTTEXT", "FIELDTYPE"=>"A"), array ("CAPTION"=>"备注", "FIELDNAME"=>"THISMEMO", "FIELDTYPE"=>"A"), array ("CAPTION"=>"服务器文件名", "FIELDNAME"=>"DOCFILE", "FIELDTYPE"=>"A"), array ("CAPTION"=>"文件类型", "FIELDNAME"=>"FILETYPE", "FIELDTYPE"=>"A"), array ("CAPTION"=>"本地文件名", "FIELDNAME"=>"FILENAME", "FIELDTYPE"=>"A"), array ("CAPTION"=>"文件扩展名", "FIELDNAME"=>"EXTNAME", "FIELDTYPE"=>"A")); //构造SQL语句,字段名部分 $strSQL = "INSERT INTO HR_WORKCONTRACT ("; $strTemp = ""; for ($i = 0; $i < $nColNum - 1; $i ++) { $strSQL .= $arrTableStru [$i]["FIELDNAME"].", "; } $strSQL .= $arrTableStru [$nColNum - 1]["FIELDNAME"].") VALUES "; $strTmp = ""; //构造SQL语句,数据部分 for ($i = 1; $i <= $nRowNum; $i ++) { $strRowChk = "RowChk".$i; if ($$strRowChk == "Y") { $strTmp .= "("; for ($j = 1; $j < $nColNum; $j ++) { $strVal = "Row" . $i . "Col" . $j; if ($arrTableStru[$j - 1]["FIELDTYPE"] == "A") { $strTmp .= "'".$$strVal."', "; } else { $strTmp .= $$strVal.", "; } } $strVal = "Row" . $i . "Col" . $nColNum; if ($arrTableStru[$nColNum - 1]["FIELDTYPE"] == "A") { $strTmp .= "'".$$strVal."'), "; } else { $strTmp .= $$strVal."), "; } if ($i % $nBatNum == 0) { $strTmp = substr ($strTmp, 0, strlen ($strTmp) - 2).";"; if (!$do->ExecSQL ($strSQL.$strTmp)) $do->SetObject ("ERR", "数据导入失败!"); else $do->SetObject ("ERR", "数据导入成功!"); //echo $strSQL.$strTmp; $strTmp = ""; } } } if (trim ($strTmp) != "") { $strTmp = substr ($strTmp, 0, strlen ($strTmp) - 2).";"; if (!$do->ExecSQL ($strSQL.$strTmp)) $do->SetObject ("ERR", "数据导入失败!"); else $do->SetObject ("ERR", "数据导入成功!"); //echo $strSQL.$strTmp; } } ?> 劳动合同信息导入
  导入数据的页面如下:   可以显示导入EXCEL文件的所有内容,并且可以手工选择要导入的数据,可以对数据进行临时的修改处理(修改过后数据以红颜色显示,以示区别)。   选择文件界面。可以选择本地硬盘上的EXCEL文件,包括XLS文件和CSV两种格式。

你可能感兴趣的:(在WEB页面上将EXCEL文件导入、导出到数据库中)