Welcome, guest | Sign In | My Account | Store | Cart

Notice! PyPM is being replaced with the ActiveState Platform, which enhances PyPM’s build and deploy capabilities. Create your free Platform account to download ActivePython or customize Python with the packages you require and get automatic updates.

Download
ActivePython
INSTALL>
pypm install cssutils

How to install cssutils

  1. Download and install ActivePython
  2. Open Command Prompt
  3. Type pypm install cssutils
 Python 2.7Python 3.2Python 3.3
Windows (32-bit)
0.9.10 Available View build log
0.9.10b1 Available View build log
0.9.9 Available View build log
0.9.8 Available View build log
0.9.8a3 Available View build log
0.9.8a2 Available View build log
0.9.8a1 Available View build log
0.9.7 Available View build log
0.9.7b4 Available View build log
0.9.7b3 Available View build log
0.9.5.1 Available View build log
0.9.10b1
0.9.10Never BuiltWhy not?
0.9.10b1 Available View build log
0.9.9 Available View build log
0.9.8 Available View build log
0.9.8a3 Available View build log
Windows (64-bit)
0.9.10 Available View build log
0.9.10b1 Available View build log
0.9.9 Available View build log
0.9.8 Available View build log
0.9.8a3 Available View build log
0.9.8a2 Available View build log
0.9.8a1 Available View build log
0.9.7 Available View build log
0.9.7b4 Available View build log
0.9.7b3 Available View build log
0.9.5.1 Available View build log
0.9.10b1
0.9.10Never BuiltWhy not?
0.9.10b1 Available View build log
0.9.9 Available View build log
0.9.8 Available View build log
0.9.8a3 Available View build log
Mac OS X (10.5+)
0.9.10 Available View build log
0.9.10b1 Available View build log
0.9.9 Available View build log
0.9.8 Available View build log
0.9.8a3 Available View build log
0.9.8a2 Available View build log
0.9.8a1 Available View build log
0.9.7 Available View build log
0.9.7b4 Available View build log
0.9.7b3 Available View build log
0.9.5.1 Available View build log
0.9.10b1
0.9.10Never BuiltWhy not?
0.9.10b1 Available View build log
0.9.9 Available View build log
0.9.8 Available View build log
0.9.8a3 Available View build log
Linux (32-bit)
0.9.10 Available View build log
0.9.10b1 Available View build log
0.9.9 Available View build log
0.9.8 Available View build log
0.9.8a3 Available View build log
0.9.8a2 Available View build log
0.9.8a1 Available View build log
0.9.7 Available View build log
0.9.7b4 Available View build log
0.9.7b3 Available View build log
0.9.5.1 Available View build log
0.9.10b1
0.9.10Never BuiltWhy not?
0.9.10b1 Available View build log
0.9.9 Available View build log
0.9.8 Available View build log
0.9.8a3 Available View build log
Linux (64-bit)
0.9.10 Available View build log
0.9.10b1 Available View build log
0.9.9 Available View build log
0.9.8 Available View build log
0.9.8a3 Available View build log
0.9.8a2 Available View build log
0.9.8a1 Available View build log
0.9.7 Available View build log
0.9.7b4 Available View build log
0.9.7b3 Available View build log
0.9.5.1 Available View build log
0.9.10b1
0.9.10Never BuiltWhy not?
0.9.10b1 Available View build log
0.9.9 Available View build log
0.9.8 Available View build log
0.9.8a3 Available View build log
0.9.10 Available View build log
0.9.9 Available View build log
 
License
LGPL 2.1 or later, see also http://cthedot.de/cssu
Lastest release
version 0.9.10 on Apr 3rd, 2013

Overview

A Python package to parse and build CSS Cascading Style Sheets. DOM only, not any rendering facilities!

Based upon and partly implementing the following specifications :

CSS 2.1rev1
General CSS rules and properties are defined here
CSS3 Module: Syntax
Used in parts since cssutils 0.9.4. cssutils tries to use the features from CSS 2.1 and CSS 3 with preference to CSS3 but as this is not final yet some parts are from CSS 2.1
CSS Fonts Module Level 3
Added changes and additional stuff (since cssutils v0.9.6)
MediaQueries
MediaQueries are part of stylesheets.MediaList since v0.9.4, used in @import and @media rules.
Namespaces
Added in v0.9.1, updated to definition in CSSOM in v0.9.4, updated in 0.9.5 for dev version
CSS3 Module: Pages Media
Most properties of this spec are implemented including MarginRules
Selectors
The selector syntax defined here (and not in CSS 2.1) should be parsable with cssutils (should mind though ;) )
CSS Backgrounds and Borders Module Level 3, CSS3 Basic User Interface Module, CSS Text Level 3
Some validation for properties included, mainly cursor, outline, resize, box-shadow, text-shadow
Variables
Experimental specification of CSS Variables which cssutils implements partly. Media specific variables are not supported.
DOM Level 2 Style CSS
DOM for package css. 0.9.8 removes support for CSSValue and related API, see PropertyValue and Value API for now
DOM Level 2 Style Stylesheets
DOM for package stylesheets
CSSOM
A few details (mainly the NamespaceRule DOM) are taken from here. Plan is to move implementation to the stuff defined here which is newer but still no REC so might change anytime...

The cssutils tokenizer is a customized implementation of CSS3 Module: Syntax (W3C Working Draft 13 August 2003) which itself is based on the CSS 2.1 tokenizer. It tries to be as compliant as possible but uses some (helpful) parts of the CSS 2.1 tokenizer.

I guess cssutils is neither CSS 2.1 nor CSS 3 compliant but tries to at least be able to parse both grammars including some more real world cases (some CSS hacks are actually parsed and serialized). Both official grammars are not final nor bugfree but still feasible. cssutils aim is not to be fully compliant to any CSS specification (the specifications seem to be in a constant flow anyway) but cssutils should be able to read and write as many as possible CSS stylesheets "in the wild" while at the same time implement the official APIs which are well documented. Some minor extensions are provided as well.

Please visit http://cthedot.de/cssutils/ or https://bitbucket.org/cthedot/cssutils/ for more details.

There is also a low-traffic cssutils discussion group.

Compatibility

cssutils is developed on standard Python but works under Python 2.x (from 2.5, 2.7.3 tested), 3.x (v3.3 tested) and Jython (from 2.5.1). IronPython has not been tested yet but might work? Python 2.4 and older are not supported since cssutils 0.9.8 anymore.

License

Copyright 2005 - 2013 Christof Hoeke

cssutils is published under the LGPL 3 or later

cssutils is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

cssutils is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public License along with cssutils. If not, see http://www.gnu.org/licenses.

Installation

From 0.9.6 cssutils uses Distribute

After installing Distribute use:

> easy_install cssutils

to install the latest version of cssutils.

Alternatively download the provided source distribution. Expand the file and from a command line install with:

> python setup.py install

To uninstall remove any registrations of cssutils eggs with Distribute and remove the eggs which should be installed at PYTHONDIR/Lib/site-packages/cssutils too.

Example

# -*- coding: utf-8 -*-
import cssutils

css = u'''/* a comment with umlaut ä */
     @namespace html "http://www.w3.org/1999/xhtml";
     @variables { BG: #fff }
     html|a { color:red; background: var(BG) }'''
sheet = cssutils.parseString(css)

for rule in sheet:
    if rule.type == rule.STYLE_RULE:
        # find property
        for property in rule.style:
            if property.name == 'color':
                property.value = 'green'
                property.priority = 'IMPORTANT'
                break
        # or simply:
        rule.style['margin'] = '01.0eM' # or: ('1em', 'important')

sheet.encoding = 'ascii'
sheet.namespaces['xhtml'] = 'http://www.w3.org/1999/xhtml'
sheet.namespaces['atom'] = 'http://www.w3.org/2005/Atom'
sheet.add('atom|title {color: #000000 !important}')
sheet.add('@import "sheets/import.css";')

# cssutils.ser.prefs.resolveVariables == True since 0.9.7b2
print sheet.cssText

results in:

@charset "ascii";
@import "sheets/import.css";
/* a comment with umlaut \E4  */
@namespace xhtml "http://www.w3.org/1999/xhtml";
@namespace atom "http://www.w3.org/2005/Atom";
xhtml|a {
    color: green !important;
    background: #fff;
    margin: 1em
    }
atom|title {
    color: #000 !important
    }

Subscribe to package updates

Last updated Apr 3rd, 2013

Download Stats

Last month:7

What does the lock icon mean?

Builds marked with a lock icon are only available via PyPM to users with a current ActivePython Business Edition subscription.

Need custom builds or support?

ActivePython Enterprise Edition guarantees priority access to technical support, indemnification, expert consulting and quality-assured language builds.

Plan on re-distributing ActivePython?

Get re-distribution rights and eliminate legal risks with ActivePython OEM Edition.