We help IT Professionals succeed at work.

MySql export to XLS (by php) problem

wal_toor
wal_toor asked
on
1,188 Views
Last Modified: 2012-05-06
Hellow all,

I have this script for exporting a mysql query to excel. This script is downloaden from: http://www.fundisom.com/phparadise/php/databases/mySQL_to_excel

One of the pieces of data that are exporter are id numbers. These are random numbers of 10 digits. But when I make an export all the id numbers starting with a zero are stripped of this zero. So numbers like '9876569033' remain like this, but numers like '0345606541'  become '345606541' in the exported xls file.
// piece of code that exports as xls
 
}else if(isset($_POST['filetype']) && ($_POST['filetype'] == 'xls')){
	/*	FORMATTING FOR EXCEL DOCUMENTS ('.xls')   */
	//create title with timestamp:
	if ($Use_Title == 1)
	{
		echo("$title\n");
	}
	//define separator (defines columns in excel & tabs in word)
	$sep = "\t"; //tabbed character
 
	//start of printing column names as names of MySQL fields
	for ($i = 0; $i < mysql_num_fields($result); $i++)
	{
		echo mysql_field_name($result,$i) . "\t";
	}
	print("\n");
	//end of printing column names
 
	//start while loop to get data
	while($row = mysql_fetch_row($result))
	{
		//set_time_limit(60); // HaRa
		$schema_insert = "";
		for($j=0; $j<mysql_num_fields($result);$j++)
		{
			if(!isset($row[$j]))
				$schema_insert .= "NULL".$sep;
			elseif ($row[$j] != "")
				$schema_insert .= "$row[$j]".$sep;
			else
				$schema_insert .= "".$sep;
		}
		$schema_insert = str_replace($sep."$", "", $schema_insert);
		//following fix suggested by Josue (thanks, Josue!)
		//this corrects output in excel when table fields contain \n or \r
		//these two characters are now replaced with a space
		$schema_insert = preg_replace("/\r\n|\n\r|\n|\r/", " ", $schema_insert);
		$schema_insert .= "\t";
		print(trim($schema_insert));
		print "\n";
	}
}else ...

Open in new window

Comment
Watch Question

Commented:
easily to solve this problem

just need add the ' into the value front
'0345606541

you can try the different in the MS Excel
when you type 0345606541 and enter, excel will auto convert to 345606541
type '0345606541, excel will show 0345606541

Author

Commented:
Hi ycTIN,

I have tried this, and works when directly working in excel, but the mysql export shows '0345606541 and will not be automatically converted.

greetz,
walter
Commented:
This one is on us!
(Get your first solution completely free - no credit card required)
UNLOCK SOLUTION

Commented:
the '  is not required in this solution

echo "<td x:str=\"$value\">";	

Open in new window

Author

Commented:
Yes, this works. I have implemented this in the existing script and works perfectly. Thanks a lot!

greetw,
walter

Author

Commented:
Works great! Thankz
Unlock the solution to this question.
Join our community and discover your potential

Experts Exchange is the only place where you can interact directly with leading experts in the technology field. Become a member today and access the collective knowledge of thousands of technology experts.

*This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply.

OR

Please enter a first name

Please enter a last name

8+ characters (letters, numbers, and a symbol)

By clicking, you agree to the Terms of Use and Privacy Policy.