Skip to main content

A django model & fixture containing common languages and culture codes

Project description

https://badge.fury.io/py/django-languages-plus.svg https://travis-ci.org/cordery/django-languages-plus.svg?branch=master https://codecov.io/gh/cordery/django-languages-plus/branch/master/graph/badge.svg

django-languages-plus provides models and fixtures for working with both common languages and ‘culture codes’ or locale codes, like pt-BR.

Note that this is only a small (but popular) subset of all living languages, and is not even a comprehensive set of the ISO 639 languages. It does however include the endonym/autonym/exonym.

The Language model contains all ISO 639-1 languages and related information from http://en.wikipedia.org/wiki/List_of_ISO_639-1_codes

The model provides the following fields (original wikipedia.org column name in parentheses).

  • name_en (ISO Language Name)

  • name_native (Native Name)

  • iso_639_1 (639-1)

  • iso_639_2T = (639-2/T)

  • iso_639_2B = (639-2/B)

  • iso_639_3 = (639-3)

  • family = (Language Family)

  • countries_spoken

Installation

pip install django-languages-plus

Usage

  1. Add languages_plus to your INSTALLED_APPS

  2. Migrate your database and load the language data fixture:

    python manage.py migrate
    python manage.py loaddata languages_data.json.gz
  3. In your code use:

    from languages_plus.models import Language
    lang = Language.objects.get(iso_639_1='en')

Generating Culture Codes (ex: pt_BR)

django-countries-plus(https://pypi.python.org/pypi/django-countries-plus) is now an explicit requirement. After installing both packages you can run the following command once to associate the two datasets and generate a list of culture codes (pt_BR for example):

from languages_plus.utils import associate_countries_and_languages
associate_countries_and_languages()

Requirements

django-countries-plus

Django: Tested for 1.11, 2.0. Should also work on most previous versions of Django 1.7+.

Running Tests

Does the code actually work?

source <YOURVIRTUALENV>/bin/activate
(myenv) $ pip install tox
(myenv) $ tox

Credits

Tools used in rendering this package:

# Changelog All notable changes to this project will be documented in this file.

The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/) and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).

## [Unreleased]

## [1.0.0] # Added - Added support and tests for Django 2.0 (thanks decibyte) - Improved associate_countries_and_languages’s handling of countries with no languages (thanks decibyte)

### Changed - Dropped Language.name_other (unused) - Dropped Language.iso_639_6 (Proposal was withdrawn [https://www.iso.org/standard/43380.html]) - The fixture is now called languages_data.json.gz - The fixture is no longer loaded by migration and must be manually loaded - Dropped test support for Django <1.11 - Cleaned up project and documentation

### Fixed - Fixed issue with Country().get_all_languages - Fixed issue with CultureCode.objects.filter_by_codes

## [0.1.6] - 2015-02-22 ### Added - Added django-countries-plus as an explicit requirement

## [0.1.5] - 2015-01-11

### Changed - Returned to the use of initial_data.

### Fixed Eliminated warning for renaming get_query_set to get_queryset.

## [0.1.4] - 2015-01-10 ### Fixed - Corrected version number on setup.py

## [0.1.3] - 2015-01-10 ### Added - Added Python 3 support. - Added basic tests for models. - Added countries plus as requirement.

### Changed - Changed the way fixtures auto loaded

## [0.1.2] - 2014-11-07 ### Fixed - Fixed gzipped fixture loading.

## [0.1.1] - 2014-11-05 ### Added - Added missing initial data fixture.

## [0.1.0] - 2014-05-21 ### Added - Initial release.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-languages-plus-1.0.0.tar.gz (20.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_languages_plus-1.0.0-py2.py3-none-any.whl (20.4 kB view details)

Uploaded Python 2Python 3

File details

Details for the file django-languages-plus-1.0.0.tar.gz.

File metadata

File hashes

Hashes for django-languages-plus-1.0.0.tar.gz
Algorithm Hash digest
SHA256 0b2ea00cd4373eb3bf21f0ccec42273560331d59e4b8c16c6c6211dd45ece565
MD5 b8bc539167226d523dc55d52f8e32b44
BLAKE2b-256 1412fd98f74b369e9f5ccdcd6a32e74e02ce182468e03c1dbea69cefd3e3b0a3

See more details on using hashes here.

File details

Details for the file django_languages_plus-1.0.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for django_languages_plus-1.0.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 b4f6084cb2d7143382e1d245c04b0806323567eb56851e82fe140301a194f75b
MD5 8b6200abc8c051b24a8d581cefb4cb76
BLAKE2b-256 7834b555e4b51b94e82bb8e494538492d0453e0ac810beda1fe02a197139577c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page