Що нового в Python 3.0

Автор:

Guido van Rossum

У цій статті пояснюється нові функції в Python 3.0 порівняно з 2.6. Python 3.0, також відомий як «Python 3000» або «Py3K», є першим випуском Python навмисно зворотно несумісним. Python 3.0 було випущено 3 грудня 2008 року. Є більше змін, ніж у типовому випуску, і більше, що є важливим для всіх користувачів Python. Проте, проаналізувавши зміни, ви побачите, що Python справді не дуже змінився — загалом, ми здебільшого виправляємо добре відомі недоліки та бородавки, а також видаляємо багато старих недоліків.

Ця стаття не намагається надати повну специфікацію всіх нових функцій, а натомість намагається дати зручний огляд. Щоб отримати повну інформацію, зверніться до документації для Python 3.0 та/або багатьох PEP, на які посилаються в тексті. Якщо ви хочете зрозуміти повну реалізацію та обґрунтування розробки певної функції, PEP зазвичай містять більше деталей, ніж звичайна документація; але зауважте, що PEP зазвичай не оновлюються після повного впровадження функції.

Через обмеження часу цей документ не такий повний, як мав би бути. Як завжди для нових випусків, файл Misc/NEWS у вихідному дистрибутиві містить велику кількість детальної інформації про кожну дрібницю, яку було змінено.

Поширені камені спотикання

У цьому розділі перераховано ті кілька змін, які, швидше за все, вас збентежать, якщо ви звикли до Python 2.5.

Перегляди та ітератори замість списків

Деякі відомі API більше не повертають списки:

  • Методи dict dict.keys(), dict.items() і dict.values() повертають «перегляди» замість списків. Наприклад, це більше не працює: k = d.keys(); k.sort(). Замість цього використовуйте k = sorted(d) (це також працює в Python 2.5 і є таким же ефективним).

  • Крім того, методи dict.iterkeys(), dict.iteritems() і dict.itervalues() більше не підтримуються.

  • map() і filter() повертають ітератори. Якщо вам справді потрібен список і всі вхідні послідовності мають однакову довжину, швидким виправленням є обернути map() у list(), наприклад. list(map(...)), але кращим виправленням часто є використання розуміння списку (особливо, коли вихідний код використовує lambda), або переписування коду, щоб він не потребував взагалі список. Особливо складним є виклик map() для побічних ефектів функції; правильним перетворенням є використання звичайного циклу for (оскільки створення списку буде марнотратним).

    Якщо вхідні послідовності не мають однакову довжину, map() зупиниться на кінці найкоротшої послідовності. Для повної сумісності з map() з Python 2.x також оберніть послідовності в itertools.zip_longest(), наприклад. map(func, *sequences) стає list(map(func, itertools.zip_longest(*sequences))).

  • range() тепер поводиться як xrange(), за винятком того, що він працює зі значеннями довільного розміру. Останнього вже не існує.

  • zip() тепер повертає ітератор.

Упорядкування порівнянь

Python 3.0 спростив правила впорядкування порівнянь:

  • Оператори порівняння порядку (<, <=, > =, >) викликають виняток TypeError, коли операнди не мають значущого природного порядку. Таким чином, такі вирази, як 1 < '', 0 > None або len <= len більше не є дійсними, і, наприклад, None < None викликає TypeError замість повернення False. Як наслідок, сортування гетерогенного списку більше не має сенсу — усі елементи мають бути порівнюваними між собою. Зауважте, що це не стосується операторів == і !=: об’єкти різних непорівнюваних типів завжди порівнюються нерівномірно.

  • builtin.sorted() і list.sort() більше не приймають аргумент cmp, що забезпечує функцію порівняння. Замість цього використовуйте аргумент key. N.B. аргументи key і reverse тепер є «лише ключовими словами».

  • Функцію cmp() слід розглядати як зниклу, а спеціальний метод __cmp__() більше не підтримується. Використовуйте __lt__() для сортування, __eq__() з __hash__() та інші детальні порівняння за потреби. (Якщо вам справді потрібна функція cmp(), ви можете використати вираз (a > b) - (a < b) як еквівалент cmp(a, b).)

Цілі числа

  • PEP 237: По суті, long перейменовано на int. Тобто, існує лише один вбудований інтегральний тип з назвою int; але він поводиться здебільшого як старий тип long.

  • PEP 238: Вираз на кшталт 1/2 повертає число з плаваючою точкою. Використовуйте 1//2, щоб отримати режим скорочення. (Останній синтаксис існував роками, принаймні з Python 2.2.)

  • Константу sys.maxint було видалено, оскільки більше немає обмежень на значення цілих чисел. Однак sys.maxsize можна використовувати як ціле число, більше за будь-який практичний список або рядковий індекс. Він відповідає «природному» цілочисельному розміру реалізації та зазвичай такий самий, як sys.maxint у попередніх випусках на тій самій платформі (припускаючи ті самі параметри збірки).

  • repr() довгого цілого числа більше не включає завершальний L, тому код, який беззастережно видаляє цей символ, замість цього відсікає останню цифру. (Натомість використовуйте str().)

  • Вісімкові літерали більше не мають форми 0720; замість цього використовуйте 0o720.

Текст Vs. Дані замість Unicode Vs. 8-бітний

Усе, що ви думали знати про двійкові дані та Юнікод, змінилося.

  • Python 3.0 використовує поняття текст і (двійкові) дані замість рядків Unicode і 8-бітних рядків. Весь текст є Unicode; однак закодований Unicode представлений як двійкові дані. Для зберігання тексту використовується тип str, а для зберігання даних — bytes. Найбільша відмінність із ситуацією 2.x полягає в тому, що будь-яка спроба змішати текст і дані в Python 3.0 викликає TypeError, тоді як якби ви змішали Unicode та 8-бітні рядки в Python 2.x, це спрацювало б якщо 8-бітний рядок містив лише 7-бітні (ASCII) байти, але ви отримаєте UnicodeDecodeError, якщо він містив значення, відмінні від ASCII. Ця ціннісна поведінка викликала багато сумних облич протягом багатьох років.

  • Як наслідок цієї зміни у філософії, майже весь код, який використовує Unicode, кодування або двійкові дані, швидше за все, має змінитися. Зміна на краще, оскільки у світі 2.x було багато помилок, пов’язаних зі змішуванням кодованого та незакодованого тексту. Щоб підготуватися до Python 2.x, почніть використовувати unicode для всього незакодованого тексту та str лише для двійкових або закодованих даних. Тоді інструмент 2to3 зробить більшу частину роботи за вас.

  • Ви більше не можете використовувати літерали u"..." для тексту Unicode. Однак ви повинні використовувати літерали b"..." для двійкових даних.

  • Оскільки типи str і bytes не можна змішувати, ви завжди повинні явно конвертувати між ними. Використовуйте str.encode() для переходу від str до bytes і bytes.decode() для переходу від bytes до str. Ви також можете використовувати bytes(s, encoding=...) та str(b, encoding=...) відповідно.

  • Як і str, тип bytes є незмінним. Існує окремий змінний тип для зберігання буферизованих двійкових даних, bytearray. Майже всі API, які приймають bytes, також приймають bytearray. Змінний API заснований на collections.MutableSequence.

  • Усі зворотні косі риски в необроблених рядкових літералах інтерпретуються буквально. Це означає, що екранування '\U' і '\u' у необроблених рядках не обробляються спеціально. Наприклад, r'\u20ac — це рядок із 6 символів у Python 3.0, тоді як у 2.6 ur'\u20ac був одним символом «євро». (Звичайно, ця зміна стосується лише необроблених рядкових літералів; у Python 3.0 символом євро є '\u20ac'.)

  • Вбудований basestring абстрактний тип було видалено. Замість цього використовуйте str. Типи str і bytes не мають достатньо спільних функціональних можливостей, щоб гарантувати спільний базовий клас. Інструмент 2to3 (див. нижче) замінює кожне входження basestring на str.

  • Файли, відкриті як текстові файли (досі стандартний режим для open()), завжди використовують кодування для відображення між рядками (у пам’яті) та байтами (на диску). Двійкові файли (відкриті за допомогою b в аргументі mode) завжди використовують байти в пам’яті. Це означає, що якщо файл відкрито з використанням неправильного режиму або кодування, введення-виведення, ймовірно, голосно завершиться помилкою, замість того, щоб мовчки видати неправильні дані. Це також означає, що навіть користувачі Unix повинні будуть вказати правильний режим (текстовий або двійковий) під час відкриття файлу. Існує залежне від платформи кодування за замовчуванням, яке на платформах Unixy можна встановити за допомогою змінної середовища LANG (і іноді також за допомогою деяких інших змінних середовища, пов’язаних із місцевими стандартами). У багатьох випадках, але не у всіх, системою за замовчуванням є UTF-8; ви ніколи не повинні розраховувати на це замовчування. Будь-яка програма, яка читає або записує більше ніж чистий текст ASCII, ймовірно, повинна мати спосіб заміни кодування. Більше немає необхідності використовувати потоки з урахуванням кодування в модулі codecs.

  • Початкові значення sys.stdin, sys.stdout і sys.stderr тепер є текстовими файлами лише у кодуванні Юнікод (тобто вони є екземплярами io. TextIOBase). Щоб читати та записувати дані байтів за допомогою цих потоків, вам потрібно використовувати їхній атрибут io.TextIOBase.buffer.

  • Імена файлів передаються та повертаються з API як рядки (Unicode). Це може спричинити проблеми, пов’язані з певною платформою, оскільки на деяких платформах імена файлів є довільними рядками байтів. (З іншого боку, у Windows імена файлів зберігаються у форматі Юнікод.) Як обхідний шлях, більшість API (наприклад, open() і багато функцій у модулі os), які приймають імена файлів, приймають: об’єкти bytes, а також рядки, а кілька API мають спосіб запитувати значення, що повертається bytes. Таким чином, os.listdir() повертає список екземплярів bytes, якщо аргумент є екземпляром bytes, а os.getcwdb() повертає поточний робочий каталог як екземпляр bytes. Зауважте, що коли os.listdir() повертає список рядків, імена файлів, які не можна правильно розшифрувати, пропускаються, а не викликають UnicodeError.

  • Деякі системні API, як-от os.environ і sys.argv, також можуть створювати проблеми, коли байти, доступні системою, не можна інтерпретувати за допомогою стандартного кодування. Встановлення змінної LANG і повторний запуск програми є, ймовірно, найкращим підходом.

  • PEP 3138: repr() рядка більше не екранує символи, відмінні від ASCII. Однак у стандарті Юнікод він все ще уникає контрольних символів і кодових точок зі статусом «недрукований».

  • PEP 3120: Стандартне кодування джерела тепер UTF-8.

  • PEP 3131: Літери, відмінні від ASCII, тепер дозволені в ідентифікаторах. (Однак стандартна бібліотека залишається лише ASCII, за винятком імен учасників у коментарях.)

  • The StringIO and cStringIO modules are gone. Instead, import the io module and use io.StringIO or io.BytesIO for text and data respectively.

  • Дивіться також Юнікод HOWTO, який було оновлено для Python 3.0.

Огляд змін синтаксису

У цьому розділі подано короткий огляд усіх синтаксичних змін у Python 3.0.

Новий синтаксис

  • PEP 3107: Аргумент функції та анотації значення, що повертається. Це забезпечує стандартизований спосіб анотування параметрів функції та значення, що повертається. Немає жодної семантики, пов’язаної з такими анотаціями, за винятком того, що їх можна перевірити під час виконання за допомогою атрибута __annotations__. Мета полягає в тому, щоб заохотити експериментувати за допомогою метакласів, декораторів або фреймворків.

  • PEP 3102: аргументи лише для ключових слів. Іменовані параметри, що виникають після *args у списку параметрів повинні вказуватися за допомогою синтаксису ключового слова під час виклику. Ви також можете використовувати голий * у списку параметрів, щоб вказати, що ви не приймаєте список аргументів змінної довжини, але у вас є аргументи лише для ключових слів.

  • Аргументи ключових слів дозволені після списку базових класів у визначенні класу. Це використовується новою конвенцією для визначення метакласу (див. наступний розділ), але також може використовуватися для інших цілей, якщо метаклас це підтримує.

  • PEP 3104: nonlocal оператор. Використовуючи nonlocal x, тепер ви можете призначати безпосередньо змінній у зовнішній (але не глобальній) області. nonlocal — нове зарезервоване слово.

  • PEP 3132: Розширене ітераційне розпакування. Тепер ви можете писати такі речі, як a, b, *rest = some_sequence. І навіть *rest, a = stuff. Об’єкт rest завжди є (можливо, порожнім) списком; права частина може бути будь-якою ітерованою. Приклад:

    (a, *rest, b) = range(5)
    

    Це встановлює a на 0, b на 4, а rest на [1, 2, 3].

  • Розуміння словника: {k: v for k, v in stuff} означає те саме, що dict(stuff), але є більш гнучким. (Це PEP 274 підтверджено. :-)

  • Встановіть літерали, напр. {1, 2}. Зауважте, що {} є порожнім словником; використовуйте set() для порожнього набору. Також підтримується розуміння набору; наприклад, {x for x in stuff} означає те саме, що set(stuff), але є більш гнучким.

  • Нові вісімкові літерали, напр. 0o720 (вже у 2.6). Старі вісімкові літерали (0720) зникли.

  • Нові бінарні літерали, напр. 0b1010 (вже у 2.6), і є нова відповідна вбудована функція, bin().

  • Байтові літерали представлено з b або B на початку, і є нова відповідна вбудована функція, bytes().

Змінений синтаксис

  • PEP 3109 і PEP 3134: новий синтаксис оператора raise: raise [expr expr]]. Дивіться нижче.

  • as і with тепер зарезервовані слова. (Насправді з 2.6.)

  • True, False і None є зарезервованими словами. (2.6 вже частково застосував обмеження на None.)

  • Змінити з except exc, var на except exc as var. Дивіться PEP 3110.

  • PEP 3115: Новий синтаксис метакласу. Замість:

    class C:
        __metaclass__ = M
        ...
    

    тепер ви повинні використовувати:

    class C(metaclass=M):
        ...
    

    Змінна module-global __metaclass__ більше не підтримується. (Це була милиця, щоб полегшити за замовчуванням класи нового стилю без отримання кожного класу від object.)

  • Розуміння списків більше не підтримує синтаксичну форму [... для var в item1, item2, ...]. Замість цього використовуйте [... для var в (item1, item2, ...)]. Також зауважте, що розуміння списків має іншу семантику: вони ближчі до синтаксичного цукру для виразу генератора всередині конструктора list(), і, зокрема, керуючі змінні циклу більше не просочуються в навколишню область.

  • Еліпсис (...) можна використовувати як атомарний вираз будь-де. (Раніше це було дозволено лише у фрагментах.) Крім того, тепер потрібно писати як .... (Раніше це також могло бути написане як ..., просто через випадковість граматики.)

Видалений синтаксис

  • PEP 3113: вилучено розпакування параметрів кортежу. Ви більше не можете писати def foo(a, (b, c)): .... Замість цього використовуйте def foo(a, b_c): b, c = b_c.

  • Видалено зворотні галочки (замість цього використовуйте repr()).

  • Видалено <> (замість цього використовуйте !=).

  • Видалено ключове слово: exec() більше не є ключовим словом; воно залишається як функція. (На щастя, синтаксис функції також був прийнятий у 2.x.) Також зауважте, що exec() більше не приймає аргумент потоку; замість exec(f) ви можете використовувати exec(f.read()).

  • Цілі літерали більше не підтримують кінцеві l або L.

  • Рядкові літерали більше не підтримують початок u або U.

  • Синтаксис from module import * дозволений лише на рівні модуля, більше не всередині функцій.

  • Єдиним прийнятним синтаксисом для відносного імпорту є from .[module] import name. Усі форми import, які не починаються з ., інтерпретуються як абсолютні імпорти. (PEP 328)

  • Класичні заняття зникли.

Зміни вже присутні в Python 2.6

Оскільки багато користувачів, ймовірно, переходять прямо з Python 2.5 на Python 3.0, цей розділ нагадує читачеві про нові функції, які спочатку були розроблені для Python 3.0, але які були перенесені на Python 2.6. Додаткові описи можна знайти у відповідних розділах Що нового в Python 2.6.

Зміни бібліотеки

Через обмеження часу цей документ не вичерпно охоплює дуже великі зміни стандартної бібліотеки. PEP 3108 є посиланням на основні зміни в бібліотеці. Ось огляд капсули:

  • Many old modules were removed. Some, like gopherlib (no longer used) and md5 (replaced by hashlib), were already deprecated by PEP 4. Others were removed as a result of the removal of support for various platforms such as Irix, BeOS and Mac OS 9 (see PEP 11). Some modules were also selected for removal in Python 3.0 due to lack of use or because a better replacement exists. See PEP 3108 for an exhaustive list.

  • The bsddb3 package was removed because its presence in the core standard library has proved over time to be a particular burden for the core developers due to testing instability and Berkeley DB’s release schedule. However, the package is alive and well, externally maintained at https://www.jcea.es/programacion/pybsddb.htm.

  • Деякі модулі були перейменовані через те, що їхня стара назва не відповідала PEP 8, або з інших причин. Ось список:

    Стара назва

    Нова назва

    _winreg

    winreg

    ConfigParser

    аналізатор конфігурації

    copy_reg

    copyreg

    Чергу

    чергу

    SocketServer

    сокетсервер

    база розмітки

    _markupbase

    репр

    reprlib

    test.test_support

    test.support

  • A common pattern in Python 2.x is to have one version of a module implemented in pure Python, with an optional accelerated version implemented as a C extension; for example, pickle and cPickle. This places the burden of importing the accelerated version and falling back on the pure Python version on each user of these modules. In Python 3.0, the accelerated versions are considered implementation details of the pure Python versions. Users should always import the standard version, which attempts to import the accelerated version and falls back to the pure Python version. The pickle / cPickle pair received this treatment. The profile module is on the list for 3.1. The StringIO module has been turned into a class in the io module.

  • Деякі пов’язані модулі були згруповані в пакети, і зазвичай назви підмодулів були спрощені. Отримані нові пакети:

    • dbm (anydbm, dbhash, dbm, dumbdbm, gdbm, whichdb).

    • html (HTMLParser, htmlentitydefs).

    • http (httplib, BaseHTTPServer, CGIHTTPServer, SimpleHTTPServer, Cookie, cookielib).

    • tkinter (усі пов’язані з Tkinter модулі, крім turtle). Цільова аудиторія turtle не дуже дбає про tkinter. Також зауважте, що починаючи з Python 2.6, функціональність turtle була значно розширена.

    • urllib (urllib, urllib2, urlparse, robotparse).

    • xmlrpc (xmlrpclib, DocXMLRPCServer, SimpleXMLRPCServer).

Деякі інші зміни до модулів стандартної бібліотеки, не охоплені PEP 3108:

  • Killed sets. Use the built-in set() class.

  • Очищення модуля sys: видалено sys.exitfunc(), sys.exc_clear(), sys.exc_type, sys.exc_value, sys.exc_traceback. (Зверніть увагу, що sys.last_type тощо залишаються.)

  • Очищення типу array.array: методи read() і write() зникли; замість цього використовуйте fromfile() і tofile(). Крім того, код типу 'c' для масиву зник — використовуйте 'b' для байтів або 'u' для символів Unicode.

  • Очищення модуля operator: видалено sequenceIncludes() і isCallable().

  • Cleanup of the thread module: acquire_lock() and release_lock() are gone; use acquire() and release() instead.

  • Очищення модуля random: видалено API jumpahead().

  • The new module is gone.

  • Функції os.tmpnam(), os.tempnam() і os.tmpfile() було видалено на користь модуля tempfile.

  • Модуль tokenize змінено для роботи з байтами. Головною точкою входу тепер є tokenize.tokenize() замість generate_tokens.

  • string.letters and its friends (string.lowercase and string.uppercase) are gone. Use string.ascii_letters etc. instead. (The reason for the removal is that string.letters and friends had locale-specific behavior, which is a bad idea for such attractively named global «constants».)

  • Змінено назву модуля __builtin__ на builtins (видалення підкреслення, додавання „s“). Змінна __builtins__, що міститься в більшості глобальних просторів імен, не змінюється. Щоб змінити вбудований модуль, ви повинні використовувати builtins, а не __builtins__!

PEP 3101: Новий підхід до форматування рядків

  • Нова система для вбудованих операцій форматування рядка замінює оператор форматування рядка %. (Однак оператор % все ще підтримується; він буде застарілим у Python 3.1 і пізніше буде видалено з мови.) Прочитайте PEP 3101, щоб отримати повну інформацію.

Зміни винятків

Було очищено API для виклику та перехоплення винятків і додано нові потужні функції:

  • PEP 352: усі винятки мають бути отримані (прямо чи опосередковано) з BaseException. Це корінь ієрархії винятків. Це не нова рекомендація, але вимога для успадкування від BaseException є новою. (Python 2.6 все ще дозволяв створювати класичні класи та не накладав обмежень на те, що ви можете перехопити.) Як наслідок, виключення рядків остаточно по-справжньому й повністю мертві.

  • Майже всі винятки насправді мають походити від Exception; BaseException слід використовувати лише як базовий клас для винятків, які слід обробляти лише на верхньому рівні, наприклад SystemExit або KeyboardInterrupt. Рекомендована ідіома для обробки всіх винятків, крім цієї останньої категорії, полягає в використанні except Exception.

  • StandardError видалено.

  • Винятки більше не діють як послідовності. Натомість використовуйте атрибут args.

  • PEP 3109: Raising exceptions. You must now use raise Exception(args) instead of raise Exception, args. Additionally, you can no longer explicitly specify a traceback; instead, if you have to do this, you can assign directly to the __traceback__ attribute (see below).

  • PEP 3110: Перехоплення винятків. Тепер ви повинні використовувати крім SomeException як variable замість крім SomeException, variable. Крім того, змінна явно видаляється, коли залишається блок except.

  • PEP 3134: Exception chaining. There are two cases: implicit chaining and explicit chaining. Implicit chaining happens when an exception is raised in an except or finally handler block. This usually happens due to a bug in the handler block; we call this a secondary exception. In this case, the original exception (that was being handled) is saved as the __context__ attribute of the secondary exception. Explicit chaining is invoked with this syntax:

    raise SecondaryException() from primary_exception
    

    (where primary_exception is any expression that produces an exception object, probably an exception that was previously caught). In this case, the primary exception is stored on the __cause__ attribute of the secondary exception. The traceback printed when an unhandled exception occurs walks the chain of __cause__ and __context__ attributes and prints a separate traceback for each component of the chain, with the primary exception at the top. (Java users may recognize this behavior.)

  • PEP 3134: Exception objects now store their traceback as the __traceback__ attribute. This means that an exception object now contains all the information pertaining to an exception, and there are fewer reasons to use sys.exc_info() (though the latter is not removed).

  • Покращено кілька повідомлень про винятки, коли Windows не вдається завантажити модуль розширення. Наприклад, код помилки 193 тепер %1 не є дійсною програмою Win32. Рядки тепер мають справу з неанглійськими локалями.

Інші інші зміни

Оператори та спеціальні методи

  • != тепер повертає протилежність ==, якщо == не повертає NotImplemented.

  • Поняття «незв’язаних методів» було видалено з мови. Посилаючись на метод як на атрибут класу, тепер ви отримуєте звичайний об’єкт функції.

  • __getslice__(), __setslice__() і __delslice__() були вбиті. Синтаксис a[i:j] тепер перекладається на a.__getitem__(slice(i, j)) (або __setitem__() або __delitem__(), коли використовується як ціль призначення або видалення відповідно).

  • PEP 3114: стандартний метод next() було перейменовано на __next__().

  • Спеціальні методи __oct__() і __hex__() видалено – oct() і hex() тепер використовують __index__() для перетворення аргументу в ціле число.

  • Видалено підтримку __members__ і __methods__.

  • The function attributes named func_X have been renamed to use the __X__ form, freeing up these names in the function attribute namespace for user-defined attributes. To wit, func_closure, func_code, func_defaults, func_dict, func_doc, func_globals, func_name were renamed to __closure__, __code__, __defaults__, __dict__, __doc__, __globals__, __name__, respectively.

  • __nonzero__() is now __bool__().

Вбудовані

  • PEP 3135: Нове super(). Тепер ви можете викликати super() без аргументів і (припускаючи, що це в звичайному методі екземпляра, визначеному всередині оператора class) правильний клас і екземпляр будуть вибрані автоматично. З аргументами поведінка super() не змінюється.

  • PEP 3111: raw_input() було перейменовано на input(). Тобто нова функція input() зчитує рядок із sys.stdin і повертає його без кінцевого символу нового рядка. Він викликає EOFError, якщо введення завершується передчасно. Щоб отримати стару поведінку input(), використовуйте eval(input()).

  • Додано нову вбудовану функцію next() для виклику методу __next__() для об’єкта.

  • Змінено стратегію округлення функції round() і тип повернення. Точні половинні випадки тепер округлюються до найближчого парного результату замість нуля. (Наприклад, round(2.5) тепер повертає 2, а не 3.) round(x[, n]) тепер делегує x.__round__([ n]) замість того, щоб завжди повертати число з плаваючою точкою. Зазвичай він повертає ціле число, якщо викликається з одним аргументом, і значення того самого типу, що й x, коли викликається з двома аргументами.

  • Переміщено intern() до sys.intern().

  • Видалено: apply(). Замість apply(f, args) використовуйте f(*args).

  • Видалено callable(). Замість callable(f) ви можете використовувати isinstance(f, collections.Callable). Функція operator.isCallable() також зникла.

  • Видалено coerce(). Ця функція більше не служить меті, оскільки класичні класи зникли.

  • Видалено execfile(). Замість execfile(fn) використовуйте exec(open(fn).read()).

  • Видалено тип file. Використовуйте open(). Зараз існує кілька різних типів потоків, які відкриваються і можуть повертатися в модулі io.

  • Видалено reduce(). Використовуйте functools.reduce(), якщо вам це дійсно потрібно; однак у 99% випадків явний цикл for читабельніший.

  • Видалено reload(). Використовуйте imp.reload().

  • Видалено. dict.has_key() – замість цього використовуйте оператор in.

Зміни збірки та C API

Через обмеження часу ось дуже неповний список змін до C API.

  • Було припинено підтримку кількох платформ, зокрема Mac OS 9, BeOS, RISCOS, Irix і Tru64.

  • PEP 3118: Новий API буфера.

  • PEP 3121: Ініціалізація та завершення модуля розширення.

  • PEP 3123: Приведення PyObject_HEAD до стандарту C.

  • Більше немає підтримки C API для обмеженого виконання.

  • PyNumber_Coerce(), PyNumber_CoerceEx(), PyMember_Get(), and PyMember_Set() C APIs are removed.

  • Новий C API PyImport_ImportModuleNoBlock(), працює як PyImport_ImportModule(), але не блокує блокування імпорту (натомість повертає помилку).

  • Перейменовано слот і метод логічного перетворення C-рівня: nb_nonzero тепер nb_bool.

  • Removed METH_OLDARGS and WITH_CYCLE_GC from the C API.

Продуктивність

Кінцевим результатом узагальнень 3.0 є те, що Python 3.0 виконує тест pystone приблизно на 10% повільніше, ніж Python 2.5. Швидше за все, найбільшою причиною є видалення спеціального регістра для малих цілих чисел. Є місце для вдосконалення, але це станеться після випуску 3.0!

Перенесення на Python 3.0

Для перенесення існуючого вихідного коду Python 2.5 або 2.6 на Python 3.0 найкраща стратегія така:

  1. (Обов’язкова умова:) Почніть із чудового тестового покриття.

  2. Порт на Python 2.6. Це повинно бути не більше роботи, ніж середнє перенесення з Python 2.x на Python 2. (x+1). Переконайтеся, що всі ваші тести пройдені.

  3. (Досі використовується 2.6:) Увімкніть перемикач командного рядка -3. Це вмикає попередження про функції, які буде видалено (або змінено) у версії 3.0. Знову запустіть набір тестів і виправте код, про який ви отримуєте попередження, доки попередження не зникнуть, і всі ваші тести все одно пройдуть.

  4. Запустіть перекладач 2to3 з джерела в джерело над вашим деревом вихідного коду. (Див. 2to3 — Automated Python 2 to 3 code translation, щоб дізнатися більше про цей інструмент.) Запустіть результат перекладу під Python 3.0. Вручну вирішуйте проблеми, що залишилися, виправляючи проблеми, доки всі тести не пройдуть знову.

Не рекомендується намагатися написати вихідний код, який працює без змін під Python 2.6 і 3.0; вам доведеться використовувати дуже спотворений стиль кодування, напр. уникнення операторів print, метакласів і багато іншого. Якщо ви підтримуєте бібліотеку, яка має підтримувати як Python 2.6, так і Python 3.0, найкращим підходом є змінити крок 3 вище, відредагувавши версію вихідного коду 2.6 і знову запустивши перекладач 2to3 замість редагування Версія вихідного коду 3.0.

Для перенесення розширень C на Python 3.0 див. Перенесення модулів розширення на Python 3.