質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

2回答

5190閲覧

「IndentationError: unindent does not match any outer indentation level」エラーについて

ruuuu

総合スコア174

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2020/01/21 03:41

以下のコードにつきまして、エラーが発生してしまった為、ご助言頂けましたら幸いです...
コードは一部抜粋となります。

from django import forms from django.contrib import admin from django.contrib.auth.models import Group from django.contrib.auth.admin import UserAdmin as BaseUserAdmin from django.contrib.auth.forms import ReadOnlyPasswordHashField from .models import User,Company,Product,Alert,Contract,log_table class UserCreationForm(forms.ModelForm): """A form for creating new users. Includes all the required fields, plus a repeated password.""" password1 = forms.CharField(label='Password', widget=forms.PasswordInput) password2 = forms.CharField(label='Password confirmation', widget=forms.PasswordInput) class Meta: model = User fields = ('email', 'username','password') def clean_password2(self): # Check that the two password entries match password1 = self.cleaned_data.get("password1") password2 = self.cleaned_data.get("password2") if password1 and password2 and password1 != password2: raise forms.ValidationError("Passwords don't match") return password2 def save(self, commit=True): # Save the provided password in hashed format user = super().save(commit=False) user.set_password(self.cleaned_data["password1"]) if commit: user.save() return user class UserChangeForm(forms.ModelForm): """A form for updating users. Includes all the fields on the user, but replaces the password field with admin's password hash display field. """ password = ReadOnlyPasswordHashField() class Meta: model = User fields = ('email', 'password', 'username','is_admin') def clean_password(self): # Regardless of what the user provides, return the initial value. # This is done here, rather than on the field, because the # field does not have access to the initial value return self.initial["password"] class UserAdmin(BaseUserAdmin): # The forms to add and change user instances form = UserChangeForm add_form = UserCreationForm # The fields to be used in displaying the User model. # These override the definitions on the base UserAdmin # that reference specific fields on auth.User. list_display = ('username','email','is_admin','is_active','created_at','updated_at') list_filter = ('is_admin',) fieldsets = ( (None, {'fields': ('email', 'password')}), ('Personal info', {'fields': ('username',)}), ('Permissions', {'fields': ('is_admin',)}), ) # add_fieldsets is not a standard ModelAdmin attribute. UserAdmin # overrides get_fieldsets to use this attribute when creating a user. add_fieldsets = ( (None, { 'classes': ('wide',), 'fields': ('email', 'username', 'password1', 'password2'), }), ) search_fields = ('email',) ordering = ('email',) filter_horizontal = () # ... and, since we're not using Django's built-in permissions, # unregister the Group model from admin. # admin.site.unregister(Group) class UserInline(admin.TabularInline): model = User can_delete = False extra = 3 class CompanyInline(admin.TabularInline): model = Company extra = 3 class ContractInline(admin.TabularInline): model = Contract can_delete = False class CompanyAdmin(admin.ModelAdmin): fieldsets = [ ('Company',{'fields': ['name'],}), (None, {'fields': ['email'],}), (None,{'fields': ['phone_numer'],}), (None,{'fields': ['company_address'],}), ] list_display = ('name','email','phone_numer','created_at','updated_at') inlines = [UserInline,ContractInline] class ProductAdmin(admin.ModelAdmin): fieldsets = [ ('Product',{'fields':['name'],}), (None,{'fields':['model_number'],}), (None,{'fields':['serial_number'],}), ] inlines = [CompanyInline] list_display = ('name','model_number','serial_number','created_at','updated_at') class ContractAdmin(admin.ModelAdmin): fieldsets = [ ('Contract',{'fields':['contract_details'],}), (None,{'fields':['billing_info'],}), ] list_display = ('created_at') # Now register the new UserAdmin... admin.site.register(User, UserAdmin) admin.site.register(Company,CompanyAdmin) admin.site.register(Product,ProductAdmin) admin.site.register(Contract,ContractAdmin)

エラーの内容は以下の通りとなります。

list_display = ('created_at') ^ IndentationError: unindent does not match any outer indentation level

こちらは調べた限りインデントが原因のエラーであるかと認識しているのですが、該当のコード付近を見直してみたのですが、インデントによる問題は見つかりません...
上記のエラーにつきまして、お気付きの点などありましたら、教えて頂けましたら幸いです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

12345 fieldsets = [ ('Contract',{'fields':['contract_details'],}), (None,{'fields':['billing_info'],}), ] 1234 list_display = ('created_at')

投稿2020/01/21 04:04

quickquip

総合スコア11055

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ruuuu

2020/01/21 04:17

ご回答ありがとうございます。 インデントを1文字ずつ数えていきましたら、「fieldsets」の前が、半角1文字分空いていました...
guest

0

list_display = ('created_at') 辺りでtabキーやspaceキーの問題でインデントエラーが起きてると思います

投稿2020/01/21 04:02

harinezumi.py

総合スコア282

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問