vb.org Archive

vb.org Archive (https://vborg.vbsupport.ru/index.php)
-   vB3 General Discussions (https://vborg.vbsupport.ru/forumdisplay.php?f=111)
-   -   [SMALL RELEASE] Average Posts / Day (https://vborg.vbsupport.ru/showthread.php?t=7852)

cpriest 02-06-2001 03:27 PM

i am sorry if this was released before i thought maybe some non-php programmers might need it :)

#####open member.php

##find:
$userinfo=$DB_site->query_first("SELECT username,joindate,lastpost,usertitle,email,showema il,invisible,homepage,icq,aim,yahoo,biography,post s FROM user WHERE userid=$userid");

##add below:
$postinfo=$DB_site->query_first("select count(postid) as total_posts, sum(LENGTH(pagetext)) as total_chars from post where userid='$userid'");

$user_join_timestamp = date("U",$userinfo[joindate]);
$system_timestamp = date("U");
$ts_difference = round(($system_timestamp - $user_join_timestamp ) / 86400);
$average_posts = round($userinfo[posts] / $ts_difference ,2);
$average_chars_per_post = round($postinfo[total_chars] / $postinfo[total_posts]);

####open your getinfo template

##find:
$totalposts

##add next to it:
(An average of $average_posts posts per day with an averge of average_chars_per_post per post)


[EDIT]:
with this code it will also show average count of letters / post!!!!!

02-06-2001 03:49 PM

Looks pretty cool.

You said the code is crappy though...will it cause any unnecessary load time due to bad queries?

Is it optimized?

02-06-2001 03:55 PM

nono, no extra queries it just uses the variables it gets from the usual UserInfo queries anyway.
all it is, is some calculating, and it's optimized to my best knowledge :)

and i said it's crappy because it's really simple ;)

02-07-2001 04:47 PM

just updated the code above to one more feature ;)

02-07-2001 05:08 PM

fix
An average of $average_posts posts per day with an average of $average_chars_per_post per post

I'm also getting an error on line
$average_posts = round($userinfo[posts] / $duh,2);

Wrong parameter count for round()

ver. 1.1.3


And here's my formatting (no reason, just posting :))
Code:

total posts<br>
Average of $average_posts posts per day<br>
Average of $average_chars_per_post characters per post


02-07-2001 07:23 PM

Where do you get $duh?

02-07-2001 09:50 PM

woops i am sorry i had two different formats of the code, and i rewrote it with nicer variable names and forgot to change that one

now it should work ;)

02-07-2001 10:29 PM

Still getting an error for
$average_posts = round($userinfo[posts] / $ts_difference ,2);

Warning: Wrong parameter count for round() in member.php3 on line 623

02-07-2001 11:49 PM

BlackJack i guess you're using php3 right ? unfortunately php3 doesnt support the precision in the round command
just replace the line with
$average_posts = round($userinfo[posts] / $ts_difference);
then, delete the ",2"

02-07-2001 11:58 PM

That did it. Thanks.

02-19-2001 04:10 PM

Another thing :) I get an error at the top of a page if the person hasn't made posts, and an instance with 1 post,

Warning: Division by zero in /www/thzclan/forums/member.php3 on line 624

0 posts - http://www.thzclan.com/forums/member...info&userid=41

and heres one with 1 post - http://www.thzclan.com/forums/member...info&userid=44

Not everybody with 1 post has the error.

I can live with this, but if there is a fix I'd apprieciate it, thanks.

PHP3

02-24-2001 02:26 PM

yEAh A FIX IS NEEDed please finish your hack:)
thanks

02-25-2001 09:37 PM

Just check before if the posts are less then 2, then the values are "N/A', else the values are what they are :P

That's how i've done it

02-28-2001 12:25 PM

Ummmm
I'm not sure what you mean, please explain...:p
thanks

02-28-2001 01:26 PM

Just use something like

PHP Code:

  $userjointimestamp=date("U",$userinfo[joindate]);
  
$systemtimestamp=date("U");
  
$tsdifference=round(($systemtimestamp-$userjointimestamp)/86400);
  
$tsdifference=$tsdifference+1;
  if (
$userinfo[posts]>=2) {
    
$averageposts=round($userinfo[posts]/$tsdifference,2);
    
$averagecharsperpost=round($postinfo[totalchars]/$postinfo[totalposts]);
  } else {
    
$averageposts="NVT";
    
$averagecharsperpost="NVT";
  } 

The only way when you NOW can get an division by zero error, is when the user's posts are deleted, but his postnumber isn't, so it still reads like 22 posts even if he hasn't got any..

But otherwise, it works fine.. for me though :)

03-01-2001 11:41 PM

How would you do this for vBB2. Can somebody make it or remodel it quickly. It would be really useful.

Thx

03-02-2001 12:14 AM

Quote:

Originally posted by mrlister
How would you do this for vBB2. Can somebody make it or remodel it quickly. It would be really useful.


Thx

it is already in vb2. Click on user profile and have a look.

03-02-2001 12:30 AM

oh ok. thx it's just that in the member.php thing it said something about mail so i got confused


All times are GMT. The time now is 05:48 PM.

Powered by vBulletin® Version 3.8.12 by vBS
Copyright ©2000 - 2025, vBulletin Solutions Inc.

X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.02074 seconds
  • Memory Usage 1,757KB
  • Queries Executed 10 (?)
More Information
Template Usage:
  • (1)ad_footer_end
  • (1)ad_footer_start
  • (1)ad_header_end
  • (1)ad_header_logo
  • (1)ad_navbar_below
  • (1)bbcode_code_printable
  • (1)bbcode_php_printable
  • (1)bbcode_quote_printable
  • (1)footer
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (6)option
  • (1)post_thanks_navbar_search
  • (1)printthread
  • (18)printthreadbit
  • (1)spacer_close
  • (1)spacer_open 

Phrase Groups Available:
  • global
  • postbit
  • showthread
Included Files:
  • ./printthread.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/class_bbcode_alt.php
  • ./includes/class_bbcode.php
  • ./includes/functions_bigthree.php 

Hooks Called:
  • init_startup
  • init_startup_session_setup_start
  • init_startup_session_setup_complete
  • cache_permissions
  • fetch_threadinfo_query
  • fetch_threadinfo
  • fetch_foruminfo
  • style_fetch
  • cache_templates
  • global_start
  • parse_templates
  • global_setup_complete
  • printthread_start
  • bbcode_fetch_tags
  • bbcode_create
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • printthread_post
  • printthread_complete