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

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

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

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

Framework

Frameworkは、アプリケーションソフトを開発する際に、一般的な機能をより簡単に、より早く完了させる事を目的とした、ソフトウェアやライブラリのセットを指します。開発にフレームワークを使用する事で、追加で必要となる機能だけを開発するだけで済む為、開発効率の向上が見込めます。

REST

REST(Representational State Transfer)はwebアプリケーションの構築スタイルの一種です。HTTP GET/POSTによってリクエストを送信し、レスポンスはXMLで返されます。SOAPのようなRPCの構築と比べるとサーバからクライアントを分離することが出来る為、人気です。

Python

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

Q&A

解決済

1回答

8978閲覧

ValueError: attempted relative import beyond top-level packageの解決方法

tomaa

総合スコア84

Django

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

Framework

Frameworkは、アプリケーションソフトを開発する際に、一般的な機能をより簡単に、より早く完了させる事を目的とした、ソフトウェアやライブラリのセットを指します。開発にフレームワークを使用する事で、追加で必要となる機能だけを開発するだけで済む為、開発効率の向上が見込めます。

REST

REST(Representational State Transfer)はwebアプリケーションの構築スタイルの一種です。HTTP GET/POSTによってリクエストを送信し、レスポンスはXMLで返されます。SOAPのようなRPCの構築と比べるとサーバからクライアントを分離することが出来る為、人気です。

Python

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

0グッド

0クリップ

投稿2020/09/30 08:27

編集2020/09/30 08:36

前提・実現したいこと

python3,django,djang_rest_frameworkを利用してWEBアプリを開発しています。

プロジェクトの中の、generics.ListAPIView,serializers.ModelSerializerに関係するファイルで、必要なmodels.pyclassをimportする際にエラーが発生し、サーバーを立ち上げることができません。

どのようにすれば、今回のエラーを解決できるでしょうか?

エラーメッセージ

importの指定のしかたでエラーメッセージが変わります。

from ..books.models import Bookをした場合:

(venv) ApplenoMacBook-Pro:project apple$ python3 manage.py runserver 〜中略〜 import_module return _bootstrap._gcd_import(name[level:], package, level) File "<frozen importlib._bootstrap>", line 1006, in _gcd_import File "<frozen importlib._bootstrap>", line 983, in _find_and_load File "<frozen importlib._bootstrap>", line 967, in _find_and_load_unlocked File "<frozen importlib._bootstrap>", line 677, in _load_unlocked File "<frozen importlib._bootstrap_external>", line 728, in exec_module File "<frozen importlib._bootstrap>", line 219, in _call_with_frames_removed File "/Users/apple/Desktop/django_rest_framework/project/api/urls.py", line 3, in <module> from .views import BookAPIView File "/Users/apple/Desktop/django_rest_framework/project/api/views.py", line 3, in <module> from .serializers import BookSerializer File "/Users/apple/Desktop/django_rest_framework/project/api/serializers.py", line 3, in <module> from ..books.models import Book ValueError: attempted relative import beyond top-level package

上記エラーのValueError: attempted relative import beyond top-level packageに対応するために、importの指定を、
from project.books.models import Bookとすると、以下のエラーメッセージとなります。

(venv) ApplenoMacBook-Pro:project apple$ python3 manage.py runserver 〜中略〜 import_module return _bootstrap._gcd_import(name[level:], package, level) File "<frozen importlib._bootstrap>", line 1006, in _gcd_import File "<frozen importlib._bootstrap>", line 983, in _find_and_load File "<frozen importlib._bootstrap>", line 967, in _find_and_load_unlocked File "<frozen importlib._bootstrap>", line 677, in _load_unlocked File "<frozen importlib._bootstrap_external>", line 728, in exec_module File "<frozen importlib._bootstrap>", line 219, in _call_with_frames_removed File "/Users/apple/Desktop/django_rest_framework/project/api/urls.py", line 3, in <module> from .views import BookAPIView File "/Users/apple/Desktop/django_rest_framework/project/api/views.py", line 3, in <module> from .serializers import BookSerializer File "/Users/apple/Desktop/django_rest_framework/project/api/serializers.py", line 3, in <module> from project.books.models import Book ModuleNotFoundError: No module named 'project.books'

該当のソースコード

ディレクトリ階層
イメージ説明

project/books/models.py

python

1from django.db import models 2 3 4class Book(models.Model): 5 title = models.CharField(max_length=250) 6 subtitle = models.CharField(max_length=250) 7 author = models.CharField(max_length=100) 8 isbn = models.CharField(max_length=13) 9 10 def __str__(self): 11 return self.title

project/api/views.py

pythonfrom

1 2from .serializers import BookSerializer 3from project.books.models import Book 4 5 6class BookAPIView(generics.ListAPIView): 7 queryset = Book.objects.all() 8 serializer_class = BookSerializer

project/api/serializers.py

python

1from rest_framework import serializers 2 3from project.books.models import Book 4 5 6class BookSerializer(serializers.ModelSerializer): 7 class Meta: 8 model = Book 9 fields = ('title', 'subtitle', 'author', 'isbn')

project/api/urls.py

python

1from django.urls import path 2 3from .views import BookAPIView 4 5 6urlpatterns = [ 7 path('', BookAPIView.as_view()), 8]

補足情報(FW/ツールのバージョンなど)

python: 3.7
django: 3.0.6
dhango_rest_framework: 3.11.0

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

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

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

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

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

guest

回答1

0

自己解決

自己解決できましたので、記入します。

エラーの原因となっていた(importできなかった)classを、以下の方法でimportする事で解決できました。
from books.models import Book

投稿2020/09/30 09:22

tomaa

総合スコア84

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問