truncatechars filter

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
from django import template
from django.template.defaultfilters import stringfilter

register = template.Library()

@register.filter(name='truncatechars')
@stringfilter
def truncatechars(value, arg):
    """
    Truncates a string after a certain number of chars.

    Argument: Number of chars to truncate after.
    """
    try:
        length = int(arg)
    except ValueError: # Invalid literal for int().
        return value # Fail silently.
    if len(value) > length:
        return value[:length] + '...'
    return value
truncatechars.is_safe = True

More like this

  1. truncate letters by trbs 7 years, 1 month ago
  2. Truncate filter by zalun 4 years, 12 months ago
  3. truncate by alfor 7 years ago
  4. Truncate words by characters by trodrigues 5 years, 11 months ago
  5. Wiki-like markup for sub templates by luckystarr 6 years, 7 months ago

Comments

sunn (on September 4, 2009):

An interesting feature would be if it only cuts whole words - like truncatewords but for chars (length then becomes the maximum length including ...)

#

allcaps (on September 4, 2009):

The interesting feature with a little problem.

Replace: return value[:length] + '...'

With: return value[:length].rsplit(" ", 1)[0] + ' ...'

>>> truncatechars("Hello World", 6)
'Hello ...'

If the length of the first word is greater or equal to arg, there is an undesirable space! >>> truncatechars("Hello World", 4) 'Hell ...'

#

(Forgotten your password?)