TalkPHP
 
 
Account Login
Latest Articles
» The basic usage of PHPTAL, a XML/XHTML template library for PHP
» Vulnerable methods and the areas they are commonly trusted in.
» Simple way to protect a form from bot
» The Basics On: How Session Stealing Works
» How to keep your forms from double posting data
IRC Channel
IRC Speech Bubble Join the friendly bunch on IRC...
(#TalkPHP on Freenode)

...Also available via a web interface.

See this thread for information on the TalkPHP Free Hugs Initiative™. Subject to availability.
Associates
Associates
CSS Tutorials
Reply
 
LinkBack Thread Tools Search this Thread Display Modes
Old 03-21-2008, 09:17 AM   #1 (permalink)
The Contributor
 
marxx's Avatar
 
Join Date: Sep 2007
Location: Finland
Posts: 45
Thanks: 3
marxx is on a distinguished road
Default Table generator?

Hi all and happy eastern! =)

I have on my new project quite many tables where I collect infos and such. I'm totally pissed of to write all over those tables and thought that if I need to changes something (class name etc) I have to go throught those all.. no way!

So, I know that it is possible to make function which generate table but would need some example of that.

Preferences as query and field names.. below is something what I came in my mind but I just can't get it work.. eh..

PHP Code:

function maketable($field$query) {

$fields[] = array($field);

print(
"<table cellspacing=\"0\" cellpaddign=\"5\" width=\"100%\">\n");

$arr mysql_query($query) or die(mysql_error());
while(
$fetch mysql_fetch_array($arr)) {

  foreach(
$fields as $f) {

    print(
"<tr><td>".$fetch[$f[0]]."</td><td>".$fetch[$f[2]]."</td></tr>\n");

  }
}
print(
"</table>\n\n");

Thanks for all help! =)
Send a message via MSN to marxx
marxx is offline  
Reply With Quote
Old 03-21-2008, 11:15 AM   #2 (permalink)
The Acquainted
 
freenity's Avatar
 
Join Date: Feb 2008
Posts: 119
Thanks: 17
freenity is on a distinguished road
Default

I think this should work:

PHP Code:

function maketable($field$query) {

$fields[] = array($field);

print(
"<table cellspacing=\"0\" cellpaddign=\"5\" width=\"100%\">\n");

$arr mysql_query($query) or die(mysql_error());
while(
$fetch mysql_fetch_array($arr)) {
  echo 
"<tr>\n";
  foreach(
$fields as $f) {
    print(
"<td>".$fetch[$f]."</td>\n");
  }
  echo 
"</tr>";
}
print(
"</table>\n\n");

Also, unless you send an array of array to $field, you can't have indices on $f, when you do foreach($fields as $f)
__________________
http://feudal-times.net - My PBB Game
http://gwphp.feudal-times.net - My Blog "Gaming With PHP"
freenity is offline  
Reply With Quote
Old 03-21-2008, 03:57 PM   #3 (permalink)
The Contributor
 
marxx's Avatar
 
Join Date: Sep 2007
Location: Finland
Posts: 45
Thanks: 3
marxx is on a distinguished road
Default

Hi Freenity, thanks for answering.

It seems that I'm missed something, I can't get it work..
I even try copy/paste hole php but no.

Then this came up. How should I make calling this function?

Now I have like this:
PHP Code:
maketable("'id', 'f1', 'f2', 'f3', 'f4'","SELECT * FROM test"); 

// edit:

I print_r $fiels and this came up
PHP Code:
Array ( [0] => Array ( [0] => idf1f2f3f4 ) ) 
So I have to explode $fields.. ok..


Thanks for all help!
Send a message via MSN to marxx
marxx is offline  
Reply With Quote
Reply



Currently Active Users Viewing This Thread: 1 (0 members and 1 guests)
 
Thread Tools Search this Thread
Search this Thread:

Advanced Search
Display Modes

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

vB code is On
Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On


All times are GMT. The time now is 03:17 PM.

 
     

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2013, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.1.0
Inactive Reminders By Icora Web Design