View Single Post
  #6  
Old 05-31-2006, 01:50 AM
jwocky jwocky is offline
 
Join Date: Mar 2005
Posts: 138
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Quote:
Originally Posted by SirAdrian
Foreach is very useful again (and in this case, all the loops are really)...

I would do something like this:
PHP Code:
// ...

$users getNames();

foreach (
$users as $user)
{
    
// $user[0] = username
    // $user[1] = start date
    // $user[2] = end date

Just a note, I changed my code earlier to a simplified version without updating the output, so check back on that. Anyway, inside this foreach loop, $user would be an array containing the user currently being processed. In here, you would display / do whatever you plan to do with each user.

Edit: echo $users[0] won't work because it is an array. It will just display "Array". To display anything, you will have to know the exact value you are searching for (or use a loop, which goes through them all). An example would be
PHP Code:
echo $users[0][0]; 
which would display the username of the first user.

@acidburn: the data is in a text file, so queries are no good here.
Adrian, absolutly perfect... this works perfectly for me. I'm still finishing up this section of my process, but basicly this is what i'm having it do, I'm having it take the first date (the start date) and compare it to today's date and my if->then statement combined with your foreach statement has done the trick so far.

FOr now I put in echo commands just to see if it was working so far, I will now replace those with the actual function I want it to do, which has to do with changing the usergroupd of that user... This will take a bit more research

PHP Code:
function comparestart($today,$users)
    {

    foreach (
$users as $user)
    {
            
// $user[0] = username
            // $user[1] = start date
            // $user[2] = end date
    /* echo $user[1]; */
    
echo "<BR>";
        if (
$today==$user[1])
        {
        echo 
$user[1];
        }

    } 

    } 
Ok...

Now on to Stage 3..

Now that this script effectivly checks the user list from a text file and checks the date against todays date, it then effectivly sorts out whos date matchs todays date.

(note in previous posts I was using actual usernames, now I will swith to userid #s to keep things simple for now.. so $user is now a number instead of a name)

Now I have it calling a function called promote() which will take that user and move him from his current usergroup to usergroup #9

I'm using this call:

PHP Code:
function promote($username)
{

$vbulletin->db->query_write("UPDATE user SET usergroupid = '" "9" "' WHERE userid IN (" $username ")"
echo $username " promoted!!" "<BR>";


Now this is not working.. I think the problem might not be just a problem with bad database query instructions, but a bigger problem. Namely, how in the world does this script know which database to use, etc etc.. Again i'm very new to this, so is there some initialization I should put at the begining of my php file to tell it what $vbulletin is, etc and where to find my databases?
Reply With Quote
 
X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.01342 seconds
  • Memory Usage 1,795KB
  • Queries Executed 11 (?)
More Information
Template Usage:
  • (1)SHOWTHREAD_SHOWPOST
  • (1)ad_footer_end
  • (1)ad_footer_start
  • (1)ad_header_end
  • (1)ad_header_logo
  • (1)ad_navbar_below
  • (4)bbcode_php
  • (1)bbcode_quote
  • (1)footer
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (6)option
  • (1)post_thanks_box
  • (1)post_thanks_button
  • (1)post_thanks_javascript
  • (1)post_thanks_navbar_search
  • (1)post_thanks_postbit_info
  • (1)postbit
  • (1)postbit_onlinestatus
  • (1)postbit_wrapper
  • (1)spacer_close
  • (1)spacer_open 

Phrase Groups Available:
  • global
  • postbit
  • reputationlevel
  • showthread
Included Files:
  • ./showpost.php
  • ./global.php
  • ./includes/init.php
  • ./includes/class_core.php
  • ./includes/config.php
  • ./includes/functions.php
  • ./includes/class_hook.php
  • ./includes/modsystem_functions.php
  • ./includes/functions_bigthree.php
  • ./includes/class_postbit.php
  • ./includes/class_bbcode.php
  • ./includes/functions_reputation.php
  • ./includes/functions_post_thanks.php 

Hooks Called:
  • init_startup
  • init_startup_session_setup_start
  • init_startup_session_setup_complete
  • cache_permissions
  • fetch_postinfo_query
  • fetch_postinfo
  • fetch_threadinfo_query
  • fetch_threadinfo
  • fetch_foruminfo
  • style_fetch
  • cache_templates
  • global_start
  • parse_templates
  • global_setup_complete
  • showpost_start
  • bbcode_fetch_tags
  • bbcode_create
  • postbit_factory
  • showpost_post
  • postbit_display_start
  • post_thanks_function_post_thanks_off_start
  • post_thanks_function_post_thanks_off_end
  • post_thanks_function_fetch_thanks_start
  • post_thanks_function_fetch_thanks_end
  • post_thanks_function_thanked_already_start
  • post_thanks_function_thanked_already_end
  • fetch_musername
  • postbit_imicons
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • postbit_display_complete
  • post_thanks_function_can_thank_this_post_start
  • showpost_complete