Problème table d'association Django-Python
Ibilolz
Messages postés
148
Statut
Membre
-
Ibilolz Messages postés 148 Statut Membre -
Ibilolz Messages postés 148 Statut Membre -
Bonjour, Je développe un site web pour le lycée ou j'effectue mon stage en python avec le framework django. Mon site va permettre aux utilisateurs de visualiser l'inventaire informatique du lycée, la configuration des machines et de demander une maintenance sur un poste précis.
J'ai repris ma BD sur PHPMyAdmin et je l'ai exporter en models pour django. J'ai une table salle, une table matériel et une table inventaire avec dedans num_salle et id_mat. Voici la déclaration de mes modèles :
J'ai un problème avec la table Emplacement, lorsque j'affiche les données des tables sur mes pages, les tables simples comme Salle et Materiel ne posent aucun soucis mais pour la table emplacement l'id_mat apparaît sous la forme Materiel object et le num_salle ne veut même pas s'afficher :
invalid literal for int() with base 10: 'S001'
alors que mon num_salle est déclaré en CHarfield et pas de problème pour l'afficher dans la table salle. Pareil dans l'interface admin de django.
Voici un screen pour vous montrer :
https://www.zupimages.net/viewer.php?id=14/23/jhab.png
https://www.zupimages.net/
J'ai repris ma BD sur PHPMyAdmin et je l'ai exporter en models pour django. J'ai une table salle, une table matériel et une table inventaire avec dedans num_salle et id_mat. Voici la déclaration de mes modèles :
class Materiel(models.Model):
id_mat = models.IntegerField(primary_key=True)
modele_mat = models.CharField(max_length=30)
date_recep = models.TextField()
marque_mat = models.CharField(max_length=30)
addmac = models.TextField()
proc_mat = models.TextField()
mem_mat = models.TextField()
dd_mat = models.TextField()
id_type_mat = models.IntegerField()
class Meta:
managed = False
db_table = 'Materiel'
class Salle(models.Model):
id_salle = models.IntegerField(primary_key=True)
num_salle = models.CharField(max_length=30)
description = models.TextField(max_length=15)
nombre_poste = models.IntegerField()
class Meta:
managed = False
db_table = 'Salle'
class Emplacement(models.Model):
id_empl = models.IntegerField(primary_key=True)
id_mat = models.ForeignKey(Materiel, db_column='id_mat')
date = models.DateField()
num_salle = models.ForeignKey(Salle, db_column='num_salle')
class Meta:
managed = False
db_table = 'emplacement'
J'ai un problème avec la table Emplacement, lorsque j'affiche les données des tables sur mes pages, les tables simples comme Salle et Materiel ne posent aucun soucis mais pour la table emplacement l'id_mat apparaît sous la forme Materiel object et le num_salle ne veut même pas s'afficher :
invalid literal for int() with base 10: 'S001'
alors que mon num_salle est déclaré en CHarfield et pas de problème pour l'afficher dans la table salle. Pareil dans l'interface admin de django.
Voici un screen pour vous montrer :
https://www.zupimages.net/viewer.php?id=14/23/jhab.png
https://www.zupimages.net/
A voir également:
- Problème table d'association Django-Python
- Table ascii - Guide
- Table des matières word - Guide
- Table des annexes word ✓ - Forum Word
- Citizen code python avis - Accueil - Outils
- Association avec le server freebox en cours freeplug vert - Forum Freebox
8 réponses
invalid literal for int() with base 10: 'S001'
Le message est clair, tu demandes de transformer la chaîne S001 en entier, ce qui est sommes toutes impossibles.
Le message est clair, tu demandes de transformer la chaîne S001 en entier, ce qui est sommes toutes impossibles.
J'ai jamais voulu la transformer en entier, je veux juste afficher mon champs. Comment je peux faire ? Voici mon template pour l'afficher :
<tr><th>Identifiant Matériel</th><th>Salle</th><th>Date de Placement</th></tr>
{% for y in dispo %}
<tr><td>{{ y.id_mat }}</td><td>{{ y.num_salle }}</td><td>{{ y.date}}</td></tr>
{% endfor %}
</table> </zed3>
J'ai jamais voulu la transformer en entier
Alors c'est django, dans ce cas, montre le traceback complet, on peut pas deviner...
num_salle, je pense devrait être un IntegerField
Alors c'est django, dans ce cas, montre le traceback complet, on peut pas deviner...
num_salle, je pense devrait être un IntegerField
Non mais le problème est dans la récupération de la valeur dans ton template.
Pour cela, tu devrais créer une méthode dans ta classe Emplacement
et modifier ton template pour accéder à cette valeur
Maintenant ne connaissant pas trop django, et ne pouvant tester, l'esprit est là...
Pour cela, tu devrais créer une méthode dans ta classe Emplacement
class Emplacement(models.Model):
id_empl = models.IntegerField(primary_key=True)
id_mat = models.ForeignKey(Materiel, db_column='id_mat')
date = models.DateField()
num_salle = models.ForeignKey(Salle, db_column='num_salle')
def getNum(self):
return int(self.num_salle.strip('S'))
class Meta:
managed = False
db_table = 'emplacement'
et modifier ton template pour accéder à cette valeur
<tr><th>Identifiant Matériel</th><th>Salle</th><th>Date de Placement</th></tr>
{% for y in dispo %}
<tr><td>{{ y.id_mat }}</td><td>{{ y.getNum() }}</td><td>{{ y.date}}</td></tr>
{% endfor %}
</table> </zed3>
Maintenant ne connaissant pas trop django, et ne pouvant tester, l'esprit est là...
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Même erreur, voici le traceback :
Environment:
Request Method: GET
Request URL: http://127.0.0.1:8000/inter1/inventaire/
Django Version: 1.6.4
Python Version: 2.7.3
Installed Applications:
('django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'django.contrib.sites',
'inter1',
'connec')
Installed Middleware:
('django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware')
Template error:
In template /home/thomas/Documents/Dev/templates/inter1/Inventaire.html, error at line 35
invalid literal for int() with base 10: 'S001'
25 : </table> </zed2>
26 :
27 :
28 : <h2> <strong><i>Disposition</i></strong> du matériel : </h2>
29 : <span onclick="showHide(this, document.getElementById('spoiler3'));">Afficher</h2></span><br>
30 : <zed3 id="spoiler3" style="display:none;">
31 :
32 : <table style="width:100%; border-spacing:0;">
33 : <tr><th>Identifiant Matériel</th><th>Salle</th><th>Date de Placement</th></tr>
34 : {% for y in dispo %}
35 : <tr><td>{{ y.id_mat }}</td><td> {{ y.num_salle }} </td><td>{{ y.date}}</td></tr>
36 : {% endfor %}
37 : </table> </zed3>
38 :
39 :
40 : {% endblock %}
41 :
42 :
43 :
44 :
45 :
Traceback:
File "/usr/local/lib/python2.7/dist-packages/django/core/handlers/base.py" in get_response
114. response = wrapped_callback(request, *callback_args, **callback_kwargs)
File "/home/thomas/Documents/Dev/inter1/views.py" in inventaire
34. return render(request, 'inter1/Inventaire.html', locals())
File "/usr/local/lib/python2.7/dist-packages/django/shortcuts/__init__.py" in render
53. return HttpResponse(loader.render_to_string(*args, **kwargs),
File "/usr/local/lib/python2.7/dist-packages/django/template/loader.py" in render_to_string
169. return t.render(context_instance)
File "/usr/local/lib/python2.7/dist-packages/django/template/base.py" in render
140. return self._render(context)
File "/usr/local/lib/python2.7/dist-packages/django/template/base.py" in _render
134. return self.nodelist.render(context)
File "/usr/local/lib/python2.7/dist-packages/django/template/base.py" in render
840. bit = self.render_node(node, context)
File "/usr/local/lib/python2.7/dist-packages/django/template/debug.py" in render_node
78. return node.render(context)
File "/usr/local/lib/python2.7/dist-packages/django/template/loader_tags.py" in render
123. return compiled_parent._render(context)
File "/usr/local/lib/python2.7/dist-packages/django/template/base.py" in _render
134. return self.nodelist.render(context)
File "/usr/local/lib/python2.7/dist-packages/django/template/base.py" in render
840. bit = self.render_node(node, context)
File "/usr/local/lib/python2.7/dist-packages/django/template/debug.py" in render_node
78. return node.render(context)
File "/usr/local/lib/python2.7/dist-packages/django/template/loader_tags.py" in render
62. result = block.nodelist.render(context)
File "/usr/local/lib/python2.7/dist-packages/django/template/base.py" in render
840. bit = self.render_node(node, context)
File "/usr/local/lib/python2.7/dist-packages/django/template/debug.py" in render_node
78. return node.render(context)
File "/usr/local/lib/python2.7/dist-packages/django/template/defaulttags.py" in render
196. nodelist.append(node.render(context))
File "/usr/local/lib/python2.7/dist-packages/django/template/debug.py" in render
88. output = self.filter_expression.resolve(context)
File "/usr/local/lib/python2.7/dist-packages/django/template/base.py" in resolve
585. obj = self.var.resolve(context)
File "/usr/local/lib/python2.7/dist-packages/django/template/base.py" in resolve
735. value = self._resolve_lookup(context)
File "/usr/local/lib/python2.7/dist-packages/django/template/base.py" in _resolve_lookup
771. current = getattr(current, bit)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/fields/related.py" in __get__
316. qs = qs.filter(**params)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/query.py" in filter
590. return self._filter_or_exclude(False, *args, **kwargs)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/query.py" in _filter_or_exclude
608. clone.query.add_q(Q(*args, **kwargs))
File "/usr/local/lib/python2.7/dist-packages/django/db/models/sql/query.py" in add_q
1198. clause = self._add_q(where_part, used_aliases)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/sql/query.py" in _add_q
1234. current_negated=current_negated)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/sql/query.py" in build_filter
1125. clause.add(constraint, AND)
File "/usr/local/lib/python2.7/dist-packages/django/utils/tree.py" in add
104. data = self._prepare_data(data)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/sql/where.py" in _prepare_data
79. value = obj.prepare(lookup_type, value)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/sql/where.py" in prepare
352. return self.field.get_prep_lookup(lookup_type, value)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/fields/__init__.py" in get_prep_lookup
1085. return super(IntegerField, self).get_prep_lookup(lookup_type, value)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/fields/__init__.py" in get_prep_lookup
369. return self.get_prep_value(value)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/fields/__init__.py" in get_prep_value
1079. return int(value)
Exception Type: ValueError at /inter1/inventaire/
Exception Value: invalid literal for int() with base 10: 'S001'
C'est que l'erreur ne vient pas de là... Peux-tu montrer le traceback complet comme demander déjà bien plutôt, en indiquant la ligne où se trouve l'erreur ?