Форум программистов, компьютерный форум, киберфорум
Python: Django
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/21: Рейтинг темы: голосов - 21, средняя оценка - 4.86
0 / 0 / 0
Регистрация: 28.03.2023
Сообщений: 10

Проблема с фикстурами - UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte

28.03.2023, 21:02. Показов 5206. Ответов 13

Студворк — интернет-сервис помощи студентам
Пытаюсь прогнать view-класс через тест с использованием трех фикстур (для продуктов, заказов и пользователей), получаю следующую ошибку: "UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte". Фикстуры ничем сторонним не открывал. Работаю на windows 10 в pycharm. Код самого теста:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
class OrdersExportTestCase(TestCase):
    fixtures = [
        'products-fixture.json',
        'orders-fixture.json',
        'users-fixture.json'
    ]
 
    @classmethod
    def setUpClass(cls):
        super().setUpClass()
        cls.user = User.objects.create_user(username='test', password='test')
        cls.user.is_staff = True
        cls.user.save()
 
    def setUp(self) -> None:
        self.client.force_login(self.user)
 
    def test_get_orders_view(self):
        response = self.client.get(reverse(
            'shopapp:orders_export'
        ))
        self.assertEqual(response.status_code, 200)
        orders = Order.objects.order_by('pk').all()
        expected_data = [
            {
                'pk': order.pk,
                'delivery_address': order.delivery_address,
                'promocode': order.promocode,
                'user_id': order.user.pk,
                'products': [product.pk for product in order.products.all()]
            }
            for order in orders
        ]
        orders_data = response.json()
        self.assertEqual(orders_data['orders'], expected_data)
 
    @classmethod
    def tearDownClass(cls):
        cls.user.delete()
Код view-класса:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
@method_decorator(user_passes_test(lambda u: u.is_staff), name='dispatch')
class OrdersExportView(View):
    def get(self, request: HttpRequest) -> JsonResponse:
        orders = Order.objects.order_by('pk').all()
        orders_data = [
            {
                'pk': order.pk,
                'delivery_address': order.delivery_address,
                'promocode': order.promocode,
                'user_id': order.user.pk,
                'products': [product.pk for product in order.products.all()]
            }
            for order in orders
        ]
 
        return JsonResponse({'orders': orders_data})
Фикстуры создавал следующими командами:
PowerShell
1
2
3
python manage.py dumpdata shopapp.Product > shopapp/fixtures/products-fixture.json
python manage.py dumpdata shopapp.Order > shopapp/fixtures/orders-fixture.json
python manage.py dumpdata auth.User > shopapp/fixtures/users-fixture.json
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
28.03.2023, 21:02
Ответы с готовыми решениями:

UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte
Всем доброе время суток. Решил сделать учебный проект. Сделал всё работало, потом дописал код и пришлось удалить и заново создать БД Mysql....

Django - UnicodeDecodeError at /member/user_locations/ 'utf8' codec can't decode byte 0xcf in position 743
Добрый день! Во всех файлах есть: # -*- coding:utf-8 -*- models.py: from django.contrib.auth.models import User ...

Unicodedecodeerror 'utf-8' codec can't decode byte 0xd1 in position 0 invalid continuation byte
Всем привет, что делать если при открытии exe файла (я так понял, он написан на питоне, писал его не я) вылезает ошибка unicodedecodeerror...

13
 Аватар для kazak
3604 / 2744 / 356
Регистрация: 11.03.2009
Сообщений: 6,307
28.03.2023, 21:48
Вариант 1. Переходить на linux, или в крайнем случае создать виртуалку.
Вариант 2. Перекодировать свои фикстуры.
Python
1
2
3
4
5
6
import json
 
with open('2.json', encoding='windows-1251') as f:
    data = json.load(f)
with open('1.json', 'w', encoding='utf-8') as f:
    json.dump(data, f, ensure_ascii=False)
0
0 / 0 / 0
Регистрация: 28.03.2023
Сообщений: 10
28.03.2023, 22:16  [ТС]
Не совсем понимаю, куда мне встроить этот код для нормальной работы. Попытался написать функцию и встроить её на этапе объявления списка фикстур, но получил ошибку "json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)
"

Python
1
2
3
4
5
6
class OrdersExportTestCase(TestCase):
    fixtures = [
        fixture_recode('products-fixture.json'),
        fixture_recode('orders-fixture.json'),
        fixture_recode('users-fixture.json')
    ]
Python
1
2
3
4
5
6
7
8
9
def fixture_recode(fixture_name):
    recoded_fixture_name = fixture_name[:-5] + '-recoded.json'
 
    with open(f'shopapp/fixtures/{fixture_name}', encoding='windows-1251') as f:
        data = json.load(f)
    with open(f'shopapp/fixtures/{recoded_fixture_name}', 'w', encoding='utf-8') as f:
        json.dump(data, f, ensure_ascii=False)
 
    return recoded_fixture_name
0
 Аватар для kazak
3604 / 2744 / 356
Регистрация: 11.03.2009
Сообщений: 6,307
28.03.2023, 22:52
Не надо его никуда встраивать, отдельно прогоните и перекодируйте свои фикстуры.
0
0 / 0 / 0
Регистрация: 28.03.2023
Сообщений: 10
29.03.2023, 11:24  [ТС]
По-прежнему получаю ошибку:
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
Traceback (most recent call last):
  File "C:\Users\Victor\PycharmProjects\future-homework\Module29 (15)\task3\main.py", line 5, in <module>
    data = json.load(f)
  File "C:\Python310\lib\json\__init__.py", line 293, in load
    return loads(fp.read(),
  File "C:\Python310\lib\json\__init__.py", line 346, in loads
    return _default_decoder.decode(s)
  File "C:\Python310\lib\json\decoder.py", line 337, in decode
    obj, end = self.raw_decode(s, idx=_w(s, 0).end())
  File "C:\Python310\lib\json\decoder.py", line 355, in raw_decode
    raise JSONDecodeError("Expecting value", s, err.value) from None
json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)
 
Process finished with exit code 1
0
 Аватар для kazak
3604 / 2744 / 356
Регистрация: 11.03.2009
Сообщений: 6,307
29.03.2023, 12:46
У Вас точно в файлах фикстур json?
0
0 / 0 / 0
Регистрация: 28.03.2023
Сообщений: 10
29.03.2023, 13:02  [ТС]
Насколько я понимаю, да. Вот, например, содержимое файла "orders-fixture.json":
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
[
  {
    "model": "shopapp.order",
    "pk": 1,
    "fields": {
      "delivery_address": "ul Street, d 11",
      "promocode": "SKILLBOX2023",
      "created_at": "2023-02-08T08:25:40.288Z",
      "user": 1,
      "products": [
        1,
        2
      ]
    }
  },
  {
    "model": "shopapp.order",
    "pk": 3,
    "fields": {
      "delivery_address": "ul. Melkaya, 44",
      "promocode": "CREATION123",
      "created_at": "2023-02-22T16:46:12.847Z",
      "user": 1,
      "products": [
        11
      ]
    }
  }
]
0
 Аватар для kazak
3604 / 2744 / 356
Регистрация: 11.03.2009
Сообщений: 6,307
29.03.2023, 15:04
Нужен не пример, а конкретный файл на котором ошибка появляется.

Expecting value: line 1 column 1 (char 0) обычно появляется либо когда файл пустой, либо когда неверный формат json'а.
0
0 / 0 / 0
Регистрация: 28.03.2023
Сообщений: 10
30.03.2023, 11:33  [ТС]
Ошибка появляется на любой из трёх фикстур. Та, которую я привёл выше, тоже вызывает ошибку (тестил каждую фикстуру отдельно).
0
 Аватар для kazak
3604 / 2744 / 356
Регистрация: 11.03.2009
Сообщений: 6,307
30.03.2023, 12:05
Можете полностью файл выложить сюда какой попроще?
0
0 / 0 / 0
Регистрация: 28.03.2023
Сообщений: 10
30.03.2023, 12:09  [ТС]
Файл "orders-fixture.json", который я выше выложил, самый простой) это не часть файла, а всё содержимое целиком
0
 Аватар для kazak
3604 / 2744 / 356
Регистрация: 11.03.2009
Сообщений: 6,307
30.03.2023, 12:12
Нет, именно сам файл, потому как с копи-пастным содержимым проблем нет.
0
0 / 0 / 0
Регистрация: 28.03.2023
Сообщений: 10
30.03.2023, 12:17  [ТС]
Отправляю архив с файлом
Вложения
Тип файла: zip orders-fixture.zip (466 байт, 11 просмотров)
0
 Аватар для kazak
3604 / 2744 / 356
Регистрация: 11.03.2009
Сообщений: 6,307
30.03.2023, 12:23
Оу, у меня notepad++ определил кодировку этого файла как utf-16
Тогда encoding='windows-1251' нужно заменить на encoding='utf-16'
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
30.03.2023, 12:23
Помогаю со студенческими работами здесь

Ошибка UnicodeDecodeError: 'utf-8' codec can't decode byte 0xcc in position 0: invalid continuation byte
Я написал код и у меня вылетела ошибка UnicodeDecodeError: 'utf-8' codec can't decode byte 0xcc in position 0: invalid continuation...

'utf-8' codec can't decode byte 0xff in position 0: invalid start byte
Сделал дамп бд так python manage.py dumpdata &gt; dump.json Пытаюсь загрузить эти данные python manage.py loaddata dump.json Получаю...

'utf-8' codec can't decode byte 0xff in position 0: invalid start byte
Работаю с библиотеками PIL и telebot В чем может быть проблема ? Ошибка - 'utf-8' codec can't decode byte 0xff in position 0:...

UnicodeDecodeError: 'utf-8' codec can't decode byte 0xc0 in position 0: invalid start byte
Добрый день!Вопрос такой-необходимо считать файл csv.Но выдает ошибку из за кодировки.Сохранял с поддержкой кодировки.Разницы нету. ...

UnicodeDecodeError: 'utf-8' codec can't decode byte 0xd7 in position 4: invalid continuation byte
Создаю бота для телеграмма на Python с Aiogram. Нужно подключить pyqiwip2p для оплат. Но постоянна выскакивает ошибка якобы не та кодировка...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru