PDA

View Full Version : PHP Reading Data


sharpkiller
01-19-2011, 03:47 PM
Hello,

I currently help run a video gaming clan, and am a webmaster for the website. My experience and knowledge of PHP is very limited; however I have been taught how to code in Turing, Visual Basic, Java, and Python. Our clan has an application process which requires administrators numerous to complete numerous steps. Essentially, we are looking to shrink this process down to a click of a button.

We currently use the Easy Forms mod for vB3, and I'm looking to collect information from the form that the script will then apply to their forum account (eg. their desired alias in the clan). However, Easy Forms does not store each field from the form in its own column of the MySQL table, and instead regurgitates the form fields into one single column on one single line. Ideally, I would have simply liked to have read the data straight from the "formresults" table and input the corresponding information into the "users" table, but that isn't possible here.

A back up plan was to go through the form line by line and collect the information that way, but it's all stored on a single line and uses BB code for formatting, so that again isn't possible here either. The method I've been taught in the other languages I know to tackle a string like this is to go through character by character and find the information I want and store it in a new variable. However, I haven't been able to find an information on how I might go to a certain position within a string with PHP to accomplish that method.

If anyone is able help with this, or suggest an alternative method, that'd be greatly appreciated. :D

Beav`
01-19-2011, 06:57 PM
Do you have an example of the string so we can see how it's formatted?

sharpkiller
01-19-2011, 07:22 PM
I've actually managed to split it up and get the details I need using the explode() function. I didn't realize you could customize the parameter of where you want the function to split the string up. Here's an example anyway in case there is a more efficient method. It stores two forms of output, I used this one with the explode() function.

a:11:{i:1;s:4:"Test";i:2;s:4:"Test";i:3;s:4:"Test";i:4;s:4:"Test";i:5;s:4:"Test";i:6;s:4:"Test";i:12;s:2:"No";i:8;s:4:"Test";i:9;s:4:"Test";i:10;s:3:"Red";i:11;s:4:"Test";}

Beav`
01-19-2011, 10:20 PM
That's a serialized array, so ideally you should use unserialize (http://uk3.php.net/manual/en/function.unserialize.php) to get the data back out again.

For example....

<?
print_r(unserialize('a:11:{i:1;s:4:"Test";i:2;s:4:"Test";i:3;s:4:"Test";i:4;s:4:"Test";i:5;s:4:"Test";i:6;s:4:"Test";i:12;s:2:"No";i:8;s:4:"Test";i:9;s:4:"Test";i:10;s:3:"Red";i:11;s:4:"Test";}'));
?>


will output...

Array
(
[1] => Test
[2] => Test
[3] => Test
[4] => Test
[5] => Test
[6] => Test
[12] => No
[8] => Test
[9] => Test
[10] => Red
[11] => Test
)

sharpkiller
01-21-2011, 12:11 PM
Cheers! Thanks for the advice. I'll definitely keep this in mind if I come across another serialized array.