Sychronized sorting?

Hello, I have a list of users and their "points", however i have tried to come up with a sorting script (using bubble sort, eww...) a few times and have failed, can someone please show me an example script that would sort data that looks like this?

BTAnamedERIK:107
RonJonSSE:57
Oz7656:1
tkdman401:25
Sou1Tear:5
EZMONEY80:20
TkeMe2UrLeadr:11
deadphishphilay:3
AngelStr641:2
IronmanGus:1
BlInK182GuRl36k:12
cEDGabriel:3
PaPaloche:4
Infested2010:2
Danamajr:2
JeeStringDiva:1
MRitchie02:1
LilCGShuo2J:2
CGorg:1
Canivour:2
WutUpKneegroe:2
PoEbAbY3424:2
MusaUGA32:4
GreatGodlyOne:2

thank you very much.
PitViperAsked:
Who is Participating?

Improve company productivity with a Business Account.Sign Up

x
 
bebonhamConnect With a Mentor Commented:
sorting is easy once you get the hang of it.

first:

sort works like this

@sorted_list=sort {comparison} @list_to_sort;

the default sort is alpha, and case sensitive.

perl uses $a and $b as references to each of the sets of two items that get compared.

so, @output= sort {$a <=> $b} @input;

would numerically sort @input into @output.

this line here,
@o=sort {substr($a,index($a,':')+1) <=> substr($b,index($b,':')+1)} @i;

takes whatever is after the ':' (substr($a,index($a,':')+1))

and compares it against the same from item two - substr($b,index($b,':')+1)


the part about {uc($a) cmp uc($b)} just converts the data to upper case, so the comparison is case sensitive.
keep in mind, anything you do to the list in the sort subroutine doesn't modify the actual data, it only tells sort what order to put it in.
 
if you have other questions, please look here
http://www.perldoc.com/perl5.6.1/pod/func/sort.html

thanks,

Bob
0
 
bebonhamCommented:
open IN, "datat.txt";  #this would be file containing data
@i=<IN>;

print "sorted alpha, case insensitive\n\n";
@o=sort {uc($a) cmp uc($b)} @i;
print @o;
print "\n\nthis is sorted by the number at the end";
@o=sort {substr($a,index($a,':')+1) <=> substr($b,index($b,':')+1)} @i;
print @o;
0
 
ozoCommented:
In what order do you want them sorted?
0
Free Tool: SSL Checker

Scans your site and returns information about your SSL implementation and certificate. Helpful for debugging and validating your SSL configuration.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

 
PitViperAuthor Commented:
bebonham - the points are your if you can explain your answer a little, it works but thats some advanced code and i'm having a hard time dissecting it. Thanks :)
0
 
bebonhamCommented:
correction....this
"the part about {uc($a) cmp uc($b)} just converts the data to upper case, so the comparison is case sensitive.
keep in mind, anything you do to the list in the sort subroutine doesn't modify "

should say the it makes the comparision NOT case sensitive
0
 
PitViperAuthor Commented:
thanks, is it possible to get it into a hash with eaze? i.e. $mypoints{$name}, would make life a lot easier :) thanks again.
0
 
bebonhamCommented:
heck yeah!!

, but keep in mind then it isn't sorted anymore...


open IN, "datat.txt";
@i=<IN>;

foreach(@i)
{
chomp($myPoints{substr($_,0,index($_,':'))}=substr($_,index($_,':')+1));
}
@k=keys %myPoints;
foreach(@k)
{
print "this dude " . $_ . " he has " . $myPoints{$_} . " points.\n";
}


0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.