acch!-- idiocy located and destroyed.

there was a null field in the countries list.

Yahoo!! thanks!

On Apr 13, 9:26 pm, "Karen Tracey" <[EMAIL PROTECTED]> wrote:
> On Sun, Apr 13, 2008 at 9:48 PM, steve skelton <[EMAIL PROTECTED]>
> wrote:
>
>
>
> > thanks - I've tried it both ways and with __str__ get the error
>
> > __str__ returned non-string (type NoneType).
>
> That's odd...
>
>
>
> > the top-level error dump is
>
> > Request Method:         GET
> > Request URL:    http://localhost:8000/admin/papers_admin/paper/35/
> > Exception Type:         TypeError
> > Exception Value:        __str__ returned non-string (type NoneType)
> > Exception Location:     C:\Python25\lib\site-packages\django\db\models
> > \fields\__init__.py in get_choices, line 302
>
> > all the models where I apply
>
> > __str__ are of the form
>
> > class LuPaperContentRegion(models.Model):
> >    paper_content_region = models.CharField(maxlength=150)
>
> >    def __str__(self):
> >        return self.paper_content_region
>
> >    class Meta:
> >        db_table='lu_paper_content_region'
>
> Are you building these models from scratch with a new database or working
> with a pre-existing database?  The fact you are specifying db_table in Meta
> makes me think maybe you are trying to map models over an already-existing
> table?  Which can be done, but if the Django model definition isn't
> correctly mapping the real table it might lead to problems.
>
> Right now as that model is defined to Django, the Django admin would not
> allow paper_content_region to be set to null, which is the only way I can
> think of that your __str__() would return None.  So I'm confused how you are
> getting this error.
>
> list to the FK model as
>
>
>
> >    Country = models.ForeignKey(LuCountry)
>
> > since this would be a link to the LuCountry table by the ID and my
> > expectation is this might display the ID in the linked table, not a
> > string so perhaps this may be the source of the problem -- but that is
> > just a guess.
>
> Now, the target for the ForeignKey here is LuCountry, which we haven't seen
> before.  Is this the one having a problem or is it the one with
> LuPaperContentRegion?  If its LuCountry that's having the problem that's the
> model we need to see.
>
> To back up to a conceptual level, what the admin is trying to do is build a
> list of all possible targets for this foreign key, in human-readable form,
> for the select drop-down box.  Under the covers it will know the primary key
> ID of each of the elements in the list, and that is what will be stored in
> the table when you select one, but to make it easier to select the right one
> it is going to present the user a friendly list.  So it's essentially going
> to select all the elements in the target table and call your __str__
> function for each one.  (There is an option to turn this off and force the
> user to enter raw IDs for cases where your tables are too large for this
> approach to work well, but you're not using that here.)
>
> So, if you are working with a pre-existing table, any null values in fields
> you are returning with __str__ could be causing this problem.  And that's
> about the only wild guess I have right now to explain what you are seeing.
>
> Karen
>
> > Thanks for your response - hopefully there is a simple thing I am not
> > getting.
>
> > On Apr 13, 8:35 pm, Michael <[EMAIL PROTECTED]> wrote:
> > > Try changing __unicode__ to __str__. The unicode merge was after .96 and
> > > therefore it isn't looking for __unicode__ to define the name of the
> > field.
>
> > > Hope that helps,
>
> > > Michael
>
> > > On Sun, Apr 13, 2008 at 9:28 PM, steve skelton <
> > [EMAIL PROTECTED]>
> > > wrote:
>
> > > > sorry I forgot to specify - am using 0.96.1 (django) and MySQL 5.0.51a
> > > > (server) and 5.1.11 (client) and my local install is on Vista laptop
> > > > with Apache and PHP also installed.
>
> > > > On Apr 13, 8:24 pm, steve skelton <[EMAIL PROTECTED]> wrote:
> > > > > Trying to get admin on my system to load values based on related
> > > > > tables on db.  I have set the FK on the papers table to tie with the
> > > > > PK of each look-up table and set models like so:
>
> > > > > class LuPaperContentEra(models.Model):
> > > > >    paper_content_era = models.CharField(blank=True, maxlength=150)
>
> > > > >    def __unicode__(self):
> > > > >        return self.paper_content_era
>
> > > > >    class Meta:
> > > > >        db_table='lu_paper_content_era'
>
> > > > > The main table, which should contain drop-downs for things like the
> > > > > model/table above, has things like:
>
> > > > > class Paper(models.Model):
> > > > >    ... many fields defined
> > > > >    PaperContent_Era = models.ForeignKey(LuPaperContentEra)
> > > > >    ... more fields defined
>
> > > > >    class Meta:
> > > > >        db_table='papers_admin'
>
> > > > >    class Admin:
> > > > >        list_display=('id','FirstName','LastName','Institution')
> > > > >        search_fields=['LastName']
>
> > > > > However, Admin displays the drop-down as
>
> > > > > LuPaperContactEra object, NOT the actual human-readable value list.
>
> > > > > I feel I am probably close to getting this to work but can't seem to
> > > > > find the right direction in which to be "nudged".
>
> > > > > Thanks!
--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To post to this group, send email to django-users@googlegroups.com
To unsubscribe from this group, send email to [EMAIL PROTECTED]
For more options, visit this group at 
http://groups.google.com/group/django-users?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to