On Tuesday, March 5, 2013 4:37:33 PM UTC-5, Cliff Kachinske wrote:
>
> Maybe one of the DAL wizards will chime in and explain how to do this in 
> the model.
>
> Until then, though, you may have to think about sorting these on the 
> controller side.
>
> First, an IP address isn't a string.  It's four octets, separated by dots. 
>  It's stored as a string, but string sorting isn't working for you.
>
> The first thing to do is break the string into its component octets, 
> something like octets = ip_addy.split('.').  Now you have a list of strings 
> but you still have a sorting problem because you need integers.  Something 
> like map(int, octets) will work.
>
> Then do 
>
> rows = db(query).select(db.sometable.ip_addy, ....).as_dict()
> for row in rows: row['order_key'] = map(int, row.ip_addy.split('.') ) 
>
> Then go here: http://docs.python.org/2/howto/sorting.html to see how to 
> sort the resulting dictionary.
>
>
>
> On Monday, March 4, 2013 5:48:41 PM UTC-5, François Delpierre wrote:
>>
>> Hi,
>>
>> How can I orderby IP address?
>> Can I write my own sort function?
>> How?
>>
>> The following code:
>> db.t_device2ip.f_ip_id.requires = IS_IN_DB(db,'t_ip.id','%(f_ip_addr)s: 
>> %(f_dns_name)s',multiple=False, orderby = 't_ip.f_ip_addr')
>>
>> Sort as if IP was a string. (well in fact it is.. but that's not the 
>> result I want to see..)
>>
>> Thanks,
>>
>

-- 

--- 
You received this message because you are subscribed to the Google Groups 
"web2py-users" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to web2py+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/groups/opt_out.


Reply via email to