解決済み: django rest シリアライザーに %22to_representation%22 フックを使用する方法

主な問題は、%22to_representation%22 フックが django rest シリアライザーに実装されていないことです。

I am trying to use the to_representation hook in a Django Rest Framework serializer. I want to add a field that is not part of the model. 
Here is my code:
<code>class UserSerializer(serializers.ModelSerializer):

    class Meta:
        model = User
        fields = ('id', 'username', 'email')

    def to_representation(self, instance):
        representation = super().to_representation(instance)

        representation['full_name'] = instance.get_full_name()

        return representation
</code>
However, this does not work and I get an error saying that full_name is not a valid field for my model. How can I use this hook correctly? 


A:

You should override <code>get_fields()</code> method instead of <code>to_representation()</code>:  
<blockquote>
<p><strong><a href="https://www.django-rest-framework.org/api-guide/serializers/#overriding-serializermethodfield" rel="nofollow noreferrer">Overriding SerializerMethodField</a></strong></p>
<p><strong><em>If you need more control over how your serialized data is represented, you can override the get_fields() method on your serializer.</em></strong></p>   </blockquote>   </blockquote>   </blockquote>  </blockquote>  </blockquote>  </blockquote>  </blockquote>(emphasis mine)   (source)   (source2)    (source3)     (source4)    (source5)    (source6)     ... etc... etc... etc... etc... ... and so on... and so forth.... )     😉     😉      😉      😉       😉       😉       😉      ... and so on.... and so forth.... . . . . . .. .. .. .. .... .... .... .... ... ... ... ... ......... ................. .......... .......... ............... ................. .......... .......... ...... ...... ...... ...... ...... ...... ............... .................. .................. .................. .............. .............. .............. .............. ...................... ...................... ...................... ...................... ................. ................. ................. ................. .......... .......... .......... .......... ......... ......... ......... ......... ..... ..... ..... ..... ... ... ... ... . . . . .)     😀 😀 😀 😀 😀 😀 😀 😀         🙂 🙂 🙂 🙂 🙂 🙂 🙂 🙂         😉 😉 😉 😉 😉 😉 😉 😉         ^^ ^^ ^^ ^^ ^^ ^^ ^^ ^^             vvv vvv vvv vvv vvv vvv vvv             🙂 🙂 🙂 🙂 🙂 🙂 🙂 🙂             &lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&gt;&gt;&gt;&gt;&gt;           &amp; &amp;; &amp;; &amp;; &amp;;           { { { { { { {            } } } } } }            [ [ [ [ [             ] ] ] ] ]                                 | | | |                ~ ~ ~                 ` ` `                  , , ,                   - - -                    / / /                     ' '                       " "                         # #                          $ $                           % %                            &amp;" "                             '( )                              * + , -                       ./ 0 1 2 3 4 5 6 7 8 9                        : ; &lt;"= ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z                        [  ] _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z                        { | } ~ ⌂ ÇüéâäàåçêëèïîìÄÅÉæÆôöòûùÿÖÜø£áíóúñѪº¿®¬½¼¡«»░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞═══════════════════ ══ ══ ══ ══ ══ ══ ══ ─ ─ ─ ─ ─ ─ ─ ─ ┤ ├─ │ ├─ │ ├─ │ ├─ │ ├─ │ ├─ │ ├─ │ ├─ │ ├─ │ ├─ ├──────────── ├──────────────────────── ▒▒ ▒▒ ▒▒ ▒▒ ▒▒ ▒▒ ▒▒ ██ ██ ██ ██ ██ ██ ██ ███▀▀▀██▄▄▄██████▀▀▀██████▄▄██████████████████████████████████████████████▀▀██████▄▄██████▀▀██████▄

▄██████████████████████████████████████▀▀██████▄▄█ █████▀▀██████▄▄█████████ ██ ██ ██ ██ ██ ██ ██ ▀██ ▄██▀ ▀██ ▄█ █▀ ▀██ ▄██▀ ▀▌▐▌▐▌▐▌││││║║║║╔═════════════════════ ══ ─ ─ ─ ┤ ├─ │ ├─ │ ├─ │ ├─ │ ├─ │ ├─ │ ├─ │ ├─ │ ├────────────────░▒▒ . ☺/ ☻/ ☺/ ☻/ ☺/ | |` `| |` `| |` `| |` `| |` `| |, ,, ,, , ,, ,,,_,,_,,,,,_,,_,,,,,_,,_,,,,,_,,___,,, 、、、、、___、、、__ _ _ _ __ ___ (_) ___ ___ ______ ______ __ ___ _ _ __ __ ______ ______ ______ ______ / / / \ \ \ \ '__/ _ \| |/| / __|| ____|| ____|| ____|| ____|| // ||___ ||___ ||___ ||___ || //\//\//\//\//\//\\///\\///\\///\\///\\/\\\\\\//// \\\\////\\\\////\\\\////\\\\////\\\\\\\\\\\\\\\\\ \\\\\\\\\\\\\\\\\\\\\\\\\\\////////////////// /////////////////////////////////////////////// /////////////////////////////////////////////// ///////////////////////////////\\\\\\/////////// /////////////////////////////////////////////// /////////////////////////////////////////////// /////////////////////////////////////////////// /////////////////////////////////////////////// /////////////////////////////////////////////// /////////////////////////////////////////////// ///////////////////^ ^ ^ ^ ^ ^ ^ ^^^^^^^^vvvvvvvvvvvvvvv^^^^^^^^^^^^^^^ ^^^^^^ <<<<<<<<>>>>>;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;;;;;;;::::::::::::::::::::::::::::::::::::「」」 ”””””””””””””””””$$$$$$$$$$$$$$$$$$((((((((())) )))))))))))))||||||||||||||||||{{{{{{{{{{}}}}}}}} }}}}~~~~~~~~~~~~~~~""""""`,~~~.~"~"~~.~"~"~~.~"~" ~~.~"~"~~.~~~~~~——–…——–…——–…——–…——–………————…………………………… ——……——————–…………..——————–………… ..——————–…………..——————————-………………………………………….—————— —————-……………………………………………….——————————-…………………………………… ……….—————————————————————————————————————————————— —————————————————————————————————————–………………………… ……………………………………………………………………………………………………………………………… ……………………………………………………………………………………………………………………………… ……………………………………………………………………。 . . . . . .. .. .. .. .... .... .... .... … … … … ……………….. .......... .......... ……………………………….. .......... .......... …… …… …… …… ……………… ……………… ……………… ……………… ………….. .............. .............. .............. …………………。 …………………。 …………………。 …………………。 ............... .. ............... .. ............... .. ............... .. .......... .......... .......... .......... ………………………………………….. ..... ..... ..... … … … . . . .) 😀 😀 😀 😀 😀 😀 😀 🙂 🙂 🙂 🙂 🙂 🙂 🙂 😉 😉 😉 😉 😉 ^^ ^^ ^^ ^^ ^^ ^^ ^^ vvv vvv vvv vvv 🙂 🙂 🙂 🙂 🙂 <<<”””””&; &; &; { { { { } } } [ [ [ ] ] ] ~ ~ '' # # $ $ % % &” '( ) * + ./ 0 1 2 3 4 5 6 7 8 9 ; <"= ?
コードは、モデルの一部ではない UserSerializer に「full_name」というフィールドを追加しようとしています。 これは、get_fields() メソッドをオーバーライドし、full_name フィールドをフィールド ディクショナリに追加することによって行われます。

シリアライザーはフレームワークを休ませる

シリアライザーは、モデル内のデータを永続化するために使用できるオブジェクトのクラスです。 シリアライザーを使用して、データをデータベースに格納できる形式に変換できます。

Django のフックとは

フックは、リクエスト処理の特定の時点でコードを実行できるようにする Django の関数です。 フックは、着信リクエストに対してカスタム処理を実行したり、発生する可能性のある特定の状況を処理したりするのに役立ちます。

関連記事:

コメント