322 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			322 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 	define ("XLSDATA_BYTE",     1,true);
 | |
| 	define ("XLSDATA_SHORT",    2,true);
 | |
| 	define ("XLSDATA_LONG",     3,true);
 | |
| 	define ("XLSDATA_FLOAT",    4,true);
 | |
| 	define ("XLSDATA_STRING",   5,true);
 | |
| 	define ("XLSDATA_LSTRING",  6,true);
 | |
| 	define ("XLSDATA_STRING1",  7,true);
 | |
| 	define ("XLSDATA_DATA32BIT",8,true);
 | |
| 	
 | |
| 	define ("XLS_BIFF5",0x0809);
 | |
| 	define ("XLS_BIFF_EOF",0x000a);
 | |
| 	define ("WORKBOOK_SHEET",0x0010);
 | |
| 	
 | |
| 	define ("BIFF_WORKBOOKGLOBALS",0x0005);
 | |
| 	define ("BIFF_CALCCOUNT",0x000c);
 | |
| 	define ("BIFF_CALCMODE",0x000d);
 | |
| 	define ("BIFF_PRECISION",0x000e);
 | |
| 	define ("BIFF_REFMODE",0x000f);
 | |
| 	define ("BIFF_DELTA",0x0010);
 | |
| 	define ("BIFF_ITERATION",0x0011);
 | |
| 	define ("BIFF_PROTECT",0x0012);
 | |
| 	define ("BIFF_PASSWORD",0x0013);
 | |
| 	define ("BIFF_PAGEHEADER",0x0014);
 | |
| 	define ("BIFF_PAGEFOOTER",0x0015);
 | |
| 	define ("BIFF_EXTERNALREFERENCESCOUNT",0x0016);
 | |
| 	define ("BIFF_EXTERNSHEET",0x0017);
 | |
| 	define ("BIFF_DEFINEDNAME",0x0018);
 | |
| 	define ("BIFF_WINDOWPROTECT",0x0019);
 | |
| 	define ("BIFF_SELECTION",0x001d);
 | |
| 	define ("BIFF_DATEMODE",0x0022);
 | |
| 	define ("BIFF_LEFTMARGIN",0x0026);
 | |
| 	define ("BIFF_RIGHTMARGIN",0x0027);
 | |
| 	define ("BIFF_TOPMARGIN",0x0028);
 | |
| 	define ("BIFF_BOTTOMMARGIN",0x0029);
 | |
| 	define ("BIFF_PRINTHEADERS",0x002a);
 | |
| 	define ("BIFF_PRINTGRIDLINES",0x002b);
 | |
| 	define ("BIFF_FONT",0x0031);
 | |
| 	define ("BIFF_CONTINUE",0x003c);
 | |
| 	define ("BIFF_WINDOW1",0x003d);
 | |
| 	define ("BIFF_BACKUP",0x0040);
 | |
| 	define ("BIFF_DEFCOLWIDTH",0x0055);
 | |
| 	define ("BIFF_WRITEACCESS",0x005c);
 | |
| 	define ("BIFF_OBJECT",0x005d);
 | |
| 	define ("BIFF_SAVERECALC",0x005f);
 | |
| 	define ("BIFF_COLINFO",0x007d);
 | |
| 	define ("BIFF_IMAGEDATA",0x007f);
 | |
| 	define ("BIFF_GUTS",0x0080);
 | |
| 	define ("BIFF_SHEETPR",0x0081);
 | |
| 	define ("BIFF_GRIDSET",0x0082);
 | |
| 	define ("BIFF_HCENTER",0x0083);
 | |
| 	define ("BIFF_VCENTER",0x0084);
 | |
| 	define ("BIFF_BOUNDSHEET",0x0085);
 | |
| 	define ("BIFF_COUNTRY",0x008c);
 | |
| 	define ("BIFF_OBJECTDISPLAYOPTIONS",0x008d);
 | |
| 	define ("BIFF_PALETTE",0x0092);
 | |
| 	define ("BIFF_FUNCTIONGROUPCOUNT",0x009c);
 | |
| 	define ("BIFF_PAGESETUP",0x00a1);
 | |
| 	define ("BIFF_TOOLBARHEADER",0x00bf);			// undocumented
 | |
| 	define ("BIFF_TOOLBAREND",0x00c0);				// undocumented
 | |
| 	define ("BIFF_MENURECORDGROUP",0x00c1);
 | |
| 	define ("BIFF_DBCELL",0x00d7);
 | |
| 	define ("BIFF_BOOKBOOL",0x00da);
 | |
| 	define ("BIFF_XFRECORD",0x00e0);
 | |
| 	define ("BIFF_INTERFACEHEADER",0x00e1);
 | |
| 	define ("BIFF_INTERFACEEND",0x00e2);
 | |
| 	define ("BIFF_MERGEDCELLS",0x00e5);
 | |
| 	
 | |
| /*
 | |
| 016FH = 367 = ASCII
 | |
| 01B5H = 437 = IBM PC CP-437 (US)
 | |
| 02D0H = 720 = IBM PC CP-720 (OEM Arabic)
 | |
| 02E1H = 737 = IBM PC CP-737 (Greek)
 | |
| 0307H = 775 = IBM PC CP-775 (Baltic)
 | |
| 0352H = 850 = IBM PC CP-850 (Latin I)
 | |
| 0354H = 852 = IBM PC CP-852 (Latin II (Central European))
 | |
| 0357H = 855 = IBM PC CP-855 (Cyrillic)
 | |
| 0359H = 857 = IBM PC CP-857 (Turkish)
 | |
| 035AH = 858 = IBM PC CP-858 (Multilingual Latin I with Euro)
 | |
| 035CH = 860 = IBM PC CP-860 (Portuguese)
 | |
| 035DH = 861 = IBM PC CP-861 (Icelandic)
 | |
| 035EH = 862 = IBM PC CP-862 (Hebrew)
 | |
| 035FH = 863 = IBM PC CP-863 (Canadian (French))
 | |
| 0360H = 864 = IBM PC CP-864 (Arabic)
 | |
| 0361H = 865 = IBM PC CP-865 (Nordic)
 | |
| 0362H = 866 = IBM PC CP-866 (Cyrillic (Russian))
 | |
| 0365H = 869 = IBM PC CP-869 (Greek (Modern))
 | |
| 036AH = 874 = Windows CP-874 (Thai)
 | |
| 03A4H = 932 = Windows CP-932 (Japanese Shift-JIS)
 | |
| 03A8H = 936 = Windows CP-936 (Chinese Simplified GBK)
 | |
| 03B5H = 949 = Windows CP-949 (Korean (Wansung))
 | |
| 03B6H = 950 = Windows CP-950 (Chinese Traditional BIG5)
 | |
| 04B0H = 1200 = UTF-16 (BIFF8)
 | |
| 04E2H = 1250 = Windows CP-1250 (Latin II) (Central European)
 | |
| 04E3H = 1251 = Windows CP-1251 (Cyrillic)
 | |
| 04E4H = 1252 = Windows CP-1252 (Latin I) (BIFF4-BIFF5)
 | |
| 04E5H = 1253 = Windows CP-1253 (Greek)
 | |
| 04E6H = 1254 = Windows CP-1254 (Turkish)
 | |
| 04E7H = 1255 = Windows CP-1255 (Hebrew)
 | |
| 04E8H = 1256 = Windows CP-1256 (Arabic)
 | |
| 04E9H = 1257 = Windows CP-1257 (Baltic)
 | |
| 04EAH = 1258 = Windows CP-1258 (Vietnamese)
 | |
| 0551H = 1361 = Windows CP-1361 (Korean (Johab))
 | |
| 2710H = 10000 = Apple Roman
 | |
| 8000H = 32768 = Apple Roman
 | |
| 8001H = 32769 = Windows CP-1252 (Latin I) (BIFF2-BIFF3)
 | |
| */
 | |
| 	define ("BIFF_CODEPAGE",0x0042);
 | |
| 	
 | |
| 	define ("BIFF_REFRESHALL",0x01b7);
 | |
| 	define ("BIFF_DIMENSIONS",0x0200);
 | |
| 	define ("BIFF_NUMBER",0x0203);
 | |
| 	define ("BIFF_LABEL",0x0204);
 | |
| 	define ("BIFF_ROW",0x0208);
 | |
| 	define ("BIFF_INDEX",0x020b);
 | |
| 	define ("BIFF_DEFAULTROWHEIGHT",0x0225);
 | |
| 	define ("BIFF_WINDOW2",0x023e);
 | |
| 	define ("BIFF_STYLEINFORMATION",0x0293);
 | |
| 	define ("BIFF_FORMAT",0x041e);
 | |
| 	define ("BIFF_SHEETPROTECTION",0x0867);
 | |
| 	
 | |
| 	class xls_bof {
 | |
| 		var $data = null;
 | |
| 		var $size = 0;
 | |
| 		var $type = null;
 | |
| 		
 | |
| 		public function __construct($aboftype=-1) {
 | |
| 			if ($aboftype==-1) { die("Error"); }
 | |
| 			$this->data = array();
 | |
| 			$this->type = $aboftype;
 | |
| 		}
 | |
| 		
 | |
| 		public function append($adatatype, $adatarec) {
 | |
| 			$new = array();
 | |
| 			$new["type"] = $adatatype;
 | |
| 			$new["data"] = $adatarec;
 | |
| 			$this->data[] = $new;
 | |
| 		}
 | |
| 		
 | |
| 		public function clear($aboftype=-1) {
 | |
| 			if ($aboftype==-1) { die("Error"); }
 | |
| 			$this->type = $aboftype;
 | |
| 			$this->data = array();
 | |
| 			return true;
 | |
| 		}
 | |
| 		
 | |
| 		public function fetch() {
 | |
| 			$output = "";
 | |
| 			foreach ($this->data as $key => $datarec) {
 | |
| 				switch ($datarec["type"]) {
 | |
| 					case XLSDATA_BYTE :	$output .= pack("C",$datarec["data"]);
 | |
| 										$this->size+=1;
 | |
| 										break;
 | |
| 										
 | |
| 					case XLSDATA_SHORT:	$output .= pack("v",$datarec["data"]);
 | |
| 										$this->size+=2;
 | |
| 										break;
 | |
| 
 | |
| 					case XLSDATA_LONG : $output .= pack("V",$datarec["data"]);
 | |
| 										$this->size+=4;
 | |
| 										break;
 | |
| 					
 | |
| 					case XLSDATA_FLOAT: $output .= pack("d",$datarec["data"]);
 | |
| 										$this->size+=8;
 | |
| 										break;
 | |
| 					
 | |
| 					case XLSDATA_DATA32BIT : 
 | |
| 										$ldata = $datarec["data"];
 | |
| 										$b3 = $ldata & 0xff;
 | |
| 										$b2 = ($ldata >> 8) & 0xff;
 | |
| 										$b1 = ($ldata >> 16) & 0xff;
 | |
| 										$b0 = ($ldata >> 24) & 0xff;
 | |
| 										$output .= pack("CCCC",$b0,$b1,$b2,$b3);
 | |
| 										$this->size+=4;
 | |
| 										break;
 | |
| 					
 | |
| 					case XLSDATA_STRING:
 | |
| 										$output .= pack("C",strlen($datarec["data"]));
 | |
| 										$this->size++;
 | |
| 										if (strlen($datarec["data"])==0) {
 | |
| 											$output .= pack("C",0x00);
 | |
| 											$this->size++;
 | |
| 											break;
 | |
| 										}
 | |
| 					
 | |
| 					case XLSDATA_STRING1:
 | |
| 										$this->size+=strlen($datarec["data"]);
 | |
| 										//$output .= pack("C",$datarec["data"]);
 | |
| 										$output .= $datarec["data"];
 | |
| 										break;
 | |
| 					case XLSDATA_LSTRING:
 | |
| 										$output .= pack("v",strlen($datarec["data"]));
 | |
| 										$this->size++;
 | |
| 										$this->size++;
 | |
| 										$this->size+=strlen($datarec["data"]);
 | |
| 										//$output .= pack("C",$datarec["data"]);
 | |
| 										$output .= $datarec["data"];
 | |
| 										break;
 | |
| 				}
 | |
| 			}
 | |
| 			return pack("vv",$this->bof,$this->size).$output;
 | |
| 		}
 | |
| 		
 | |
| 		public function save($afilehd) {
 | |
| 			$this->bof = $this->type;
 | |
| 			$this->size = 0;
 | |
| 			$tmp = $this->fetch();
 | |
| 			if ($this->size<2080) {
 | |
| 				fwrite($afilehd,$tmp);
 | |
| 			}
 | |
| 			else {
 | |
| 				if (defined("BIFFDEBUG")) {
 | |
| 					echo "long record - size : ".$this->size."<br>";
 | |
| 				}
 | |
| 				$wcount = $this->size;
 | |
| 				$tmptype = $this->type;
 | |
| 				$tmp = substr($tmp,4);
 | |
| 				$tmparr = str_split($tmp,2076);
 | |
| 				if (defined("BIFFDEBUG")) {
 | |
| 					echo "create parts : ".count($tmparr)."<br>";
 | |
| 				}
 | |
| 				$tmpout = "";
 | |
| 				foreach ($tmparr as $key => $datapart) {
 | |
| 					if (defined("BIFFDEBUG")) {
 | |
| 						echo "part ($key) size : ".strlen($datapart)."<br>";
 | |
| 					}
 | |
| 					$tmpout = pack("vv",$tmptype,strlen($datapart)).$datapart;
 | |
| 					fwrite($afilehd,$tmpout);
 | |
| 					$tmptype = BIFF_CONTINUE;
 | |
| 				}
 | |
| 				unset($tmparr);
 | |
| 			}
 | |
| 			return true;
 | |
| 		}
 | |
| 		
 | |
| 		public function workbookxfrecords($afilehd) {
 | |
| 			$this->workbookonexfdata($afilehd,0x0000,0x0000,0xfff5,0x00,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0001,0x0000,0xfff5,0xf4,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0001,0x0000,0xfff5,0xf4,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0002,0x0000,0xfff5,0xf4,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0002,0x0000,0xfff5,0xf4,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0000,0x0000,0xfff5,0xf4,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0000,0x0000,0xfff5,0xf4,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0000,0x0000,0xfff5,0xf4,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0000,0x0000,0xfff5,0xf4,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0000,0x0000,0xfff5,0xf4,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0000,0x0000,0xfff5,0xf4,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0000,0x0000,0xfff5,0xf4,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0000,0x0000,0xfff5,0xf4,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0000,0x0000,0xfff5,0xf4,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0000,0x0000,0xfff5,0xf4,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0000,0x0000,0x0001,0x00,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0001,0x002b,0xfff5,0xf8,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0001,0x0029,0xfff5,0xf8,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0001,0x002c,0xfff5,0xf8,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0001,0x002a,0xfff5,0xf8,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0001,0x0009,0xfff5,0xf8,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0000,0x0000,0x0001,0x10,0x000020c0);
 | |
| 			$this->workbookonexfdata($afilehd,0x0000,0x0000,0x0001,0x50,0x00000488);
 | |
| 		}
 | |
| 		
 | |
| 		public function workbookonexfdata($afilehd, $fontindex, $formatindex, $xftype, $textorientation, $colorindexs) {
 | |
| 			$this->clear(BIFF_XFRECORD);
 | |
| 			$this->append(XLSDATA_SHORT,$fontindex);
 | |
| 			$this->append(XLSDATA_SHORT,$formatindex);
 | |
| 			$this->append(XLSDATA_SHORT,$xftype);
 | |
| 			$this->append(XLSDATA_BYTE,0x20);				/* alignment
 | |
| 														   bits mask
 | |
| 															2-0 07H XF_HOR_ALIGN ? Horizontal alignment
 | |
| 																0 General
 | |
| 																1 Left
 | |
| 																2 Centred
 | |
| 																3 Right
 | |
| 																4 Filled
 | |
| 																5 Justified (BIFF4-BIFF8)
 | |
| 																6 Centred across selection (BIFF4-BIFF8)
 | |
| 																7 Distributed (BIFF8, available in Excel 10.0 (Excel XP) and later only)
 | |
| 															3 08H 1 = Text is wrapped at right border
 | |
| 															6-4 70H XF_VERT_ALIGN ? Vertical alignment
 | |
| 																0 Top
 | |
| 																1 Centred
 | |
| 																2 Bottom
 | |
| 																3 Justified (BIFF5-BIFF8)
 | |
| 																4 Distributed (BIFF8, available in Excel 10.0 (Excel XP) and later only)
 | |
| 															*/			
 | |
| 			$this->append(XLSDATA_BYTE,$textorientation);	/* 
 | |
| 															bits mask
 | |
| 															1-0 03H XF_ORIENTATION ? Text orientation
 | |
| 																0 Not rotated
 | |
| 																1 Letters are stacked top-to-bottom, but not rotated
 | |
| 																2 Text is rotated 90 degrees counterclockwise
 | |
| 																3 Text is rotated 90 degrees clockwise
 | |
| 															7-2 FCH XF_USED_ATTRIB ? Used attributes
 | |
| 																0 01H Flag for number format
 | |
| 																1 02H Flag for font
 | |
| 																2 04H Flag for horizontal and vertical alignment, text wrap, indentation, orientation, rotation, and text direction
 | |
| 																3 08H Flag for border lines
 | |
| 																4 10H Flag for background area style
 | |
| 																5 20H Flag for cell protection (cell locked and formula hidden)
 | |
| 															*/
 | |
| 			$this->append(XLSDATA_LONG,$colorindexs);		/* Cell border lines and background area:
 | |
| 															Bit     Mask       Contents
 | |
| 															6-0   0000007FH Colour index for pattern colour
 | |
| 															13-7  00003F80H Colour index for pattern background
 | |
| 															21-16 003F0000H Fill pattern 
 | |
| 															24-22 01C00000H Bottom line style 
 | |
| 															31-25 FE000000H Colour index for bottom line colour
 | |
| 															*/
 | |
| 			$this->append(XLSDATA_LONG,0);					/* Line styles
 | |
| 															Bit     Mask       Contents
 | |
| 															2-0   00000007H Top line style
 | |
| 															5-3   00000038H Left line style
 | |
| 															8-6   000001C0H Right line style
 | |
| 															15-9  0000FE00H Colour index for top line colour
 | |
| 															22-16 007F0000H Colour index for left line colour
 | |
| 															29-23 3F800000H Colour index for right line colour
 | |
| 															*/
 | |
| 			$this->save($afilehd);
 | |
| 		}
 | |
| 		
 | |
| 	}
 | |
| ?>
 |