That's a bit more involved.  For groupby you need to build a query using | 
and for left you need a list of db.table.on().  Have a look at the sample 
code below for a rough outline of the process.

    grouping_fields = [db.table.field1, db.table.field2]
    groupby = grouping_fields[0]
    if len(grouping_fields) > 1:
        for g in grouping_fields[1:]:
            groupby = groupby|g
    fields = fields + grouping_fields # the grouping fields must be selected
    left = [db.table1.on((db.table1.id == db.table2.table1_id)), 
db.table1.on((db.table1.id == db.table3.table1_id))]
    rows = db(query).select(*fields, groupby=groupby, left=left)




On Saturday, 18 April 2015 14:50:37 UTC+12, Sébastien Loix wrote:
>
> One last thing, any idea if it is also possible to dynamically add 
> "left=[.....], orderby=...."
>
> For now I can't as it (logically) tells me that 'append() takes no keyword 
> arguments'
>
> thank you! 
>
> On Wednesday, 15 April 2015 00:52:53 UTC+2, Limedrop wrote:
>>
>> You can do this by building a list of fields and then using the python 
>> unpack operator.  For example:
>>
>> field_list = [db.auth_user.first_name]
>> if ask_for_lastname:
>>     field_list.append(db.auth_user.last_name)
>> rows = db(query).select(*field_list)
>>
>> See 
>> https://docs.python.org/2/tutorial/controlflow.html#unpacking-argument-lists
>>
>>

-- 
Resources:
- http://web2py.com
- http://web2py.com/book (Documentation)
- http://github.com/web2py/web2py (Source code)
- https://code.google.com/p/web2py/issues/list (Report Issues)
--- 
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/d/optout.

Reply via email to