Skip to main content

Export dexterity contents in an excel file, one column by field

Project description

What does this product

This product provides tools to provide excel exports to Plone users, under xls or csv format.

A framework, with default utilities to export the dexterity contents of a folder, the results of a catalog search, and the results of a eea faceted navigation search. Many field types are managed (text, list, file, boolean, datagrid…).

Try @@collective.excelexport view on any folder containing dexterity elements. Try @@collective.excelexport?excelexport.policy=excelexport.search&review_state=published on site root.

Try @@collective.excelexportcsv view on any folder for csv export.

Translations

This product has been translated into

  • French.

  • Spanish.

You can contribute for any message missing or other new languages, join us at Plone Collective Team into Transifex.net service with all world Plone translators community.

Installation

Install collective.excelexport by adding it to your buildout:

[buildout]

eggs =

collective.excelexport

and then running “bin/buildout”

How to configure this product

You can set a list of fields to be excluded from export via the registry record: collective.excelexport.excluded_exportables

How to extend it

Datasources

If you want to implement a new way to get content to export, you can register a #datasource#, which is an adapter for collective.excelexport.interfaces.IDataSource interface.

This adapter can be a named one.

You will call this datasource calling the view @@collective.excelexport?excelexport.policy=datasourcename

See the IDataSource interface for more information

Exportables (excel sheet columns)

If you want to define new columns for your excel export, you will write or override:

- Exportable factories, adapters for IExportableFactory interface that provides a list of Exportables
- Exportables, that define columns.

Example of an exportable factory:

from plone.dexterity.interfaces import IDexterityFTI
from collective.excelexport.exportables.base import BaseExportableFactory
from collective.excelexport.exportables.dexterityfields import get_ordered_fields
from collective.excelexport.exportables.dexterityfields import get_exportable
from collective.excelexport.exportables.dexterityfields import ParentField
from collective.excelexport.exportables.dexterityfields import GrandParentField

class PSTActionFieldsFactory(BaseExportableFactory):
    adapts(IDexterityFTI, Interface, Interface)
    portal_types = ('pstaction',)

    def get_exportables(self):
        portal_types = api.portal.get_tool('portal_types')
        action_fti = portal_types['pstaction']
        oo_fti = portal_types['operationalobjective']
        os_fti = portal_types['strategicobjective']
        fields = []
        fields.extend([get_exportable(
            field[1], self.context, self.request)
            for field in get_ordered_fields(action_fti)])
        fields.extend([get_exportable(
            ParentField(field[1]), self.context, self.request)
            for field in get_ordered_fields(oo_fti)])
        fields.extend([get_exportable(
            GrandParentField(field[1]), self.context, self.request)
            for field in get_ordered_fields(os_fti)])
        return fields

Dexterity exportables

You have a complete set of exportables for dexterity fields. Those are multi-adapters of field, context and request.

You can override them declaring a more specific adapter.

You can also declare a named adapter with the field name if you want a specific rendering for one field.

Styles

If you don’t feel good with default styles, you can register a specific one for: ::
  • the export policy

  • the context

  • the layer

You just have to register a new IStyle adapter, in a zcml:

<adapter for="zope.interface.Interface
              .interfaces.IThemeSpecific"
         factory=".excelstyles.MyNeutralStyle"
         provides="collective.excelexport.interfaces.IStyles"
          />

If you do not specify the name, the styles will be registered for all policies.

and in python:

class MyNeutralStyle(Styles):

    content = xlwt.easyxf('font: height 200, name Arial, colour_index black, bold off; '
                     'align: wrap off, vert centre, horiz left;'
                     'borders: top thin, bottom thin, left thin, right thin;'
                     'pattern: pattern solid, back_colour white, fore_colour white'
                     )

    headers = xlwt.easyxf('font: height 200, name Arial, colour_index black, bold on; '
                         'align: wrap off, vert centre, horiz left; '
                         'borders: top thin, bottom thin, left thin, right thin; '
                         'pattern: pattern solid, back_colour white, fore_colour white; '
                         )

plone.restapi

To get an export via rest api, query @collective.excelexport / @collective.excelexportcsv (with one @)

Versions

  • Version 2.x is for Plone 6+ only

  • Version 1.x is for Plone 4 / 5

Tests status

This add-on is tested using Github action. The current status of the add-on is:

https://github.com/collective/collective.excelexport/actions/workflows/main.yml/badge.svg https://coveralls.io/repos/github/collective/collective.excelexport/badge.svg PyPI badge

Contribute

Have an idea? Found a bug? Let us know by opening a ticket.

License

The project is licensed under the GPLv2.

Contributors

Changelog

2.0 (2025-09-04)

  • Add Plone 6 compatibility, drop Plone 4 & Plone 5 compatibility [laulaz]

  • Add uninstall profile [laulaz]

  • Added Transifex.net service integration to manage the translation process. [macagua]

  • Added Spanish translation. [macagua]

  • Updated the i18n support. [macagua]

1.8.2 (2020-02-27)

  • Add Python 3 compatibility. [bsuttor]

1.8.1 (2019-11-06)

  • Safely decode voc_value (fix encoding issue) + test [boulch]

1.8 (2019-09-12)

# BREAKING CHANGES

CONFIGURATION_FIELDS constant has been removed, we now use a registry record: collective.excelexport.excluded_exportables

# CHANGES

  • Explicit inclusion of plone.restapi zcml [thomasdesvenain]

  • Exclude dexterity ‘allow discussion’ and ‘exclude_from_nav’ fields (previously, only archetypes fields were excluded) [thomasdesvenain]

  • Fix error when referenced object value has no Title method. [thomasdesvenain]

  • Fix: Don’t ommit fields that are in the default fieldset if there is one [petchesi-iulian]

  • Fix error on eea.faceted when there is a widget operator. [thomasdesvenain]

  • Archetypes support, Products.ATExtensions support (RecordField, RecordsField, FormattableNamesField). [thomasdesvenain]

  • Fix encoding issue.

1.7 (2018-06-22)

  • Added plone.restapi service. [thomasdesvenain]

  • Fixed csv export mimetype.

  • Added helper method get_exportable_for_fieldname. [gbastien]

1.6 (2018-01-05)

  • Fix: no limit for number of results in eeafaceted datasource. [cedricmessiant]

1.5 (2017-11-28)

  • Upgrade bootstrap. [sgeulette]

  • Fix: render choice field with source vocabulary [sgeulette]

1.4 (2017-05-31)

  • Prevent removal of exportables with similar names when ordering them [thomasdesvenain]

  • Refactor: view exposes method that creates data buffer from sheet data. [thomasdesvenain]

  • Made correct release [sgeulette]

1.3 (2016-11-28)

  • Fix: check if value_type is empty for collection field render. [bsuttor]

  • Fix: try to get the value of a method if the field is a method and translate DateTime results to a unicode, this fixes the export for objects with the IPublication Behavior. [pcdummy]

  • Fix: be sure to not retrieve an attribute on an object by acquisition. [vincentfretin]

  • Feature: render_style can now return a Style object with content and headers attribute to be able to customise the header style per exportable. [vincentfretin]

  • Feature: the passed obj to render_value is now exportable.field.bind(obj).context to make it easier to get data from parent or grandparent. [vincentfretin]

  • Feature: BaseFieldRenderer.render_header method returns now the translated field title instead of the Message object. [vincentfretin]

  • Fix: Ignore reverse parameter when creating export url. [cedricmessiant]

  • Feature: Add sort exportables feature using exportables_order list. Works with field and non-field exportables. [cedricmessiant, ebrehault, thomasdevenain]

1.2 (2014-09-10)

  • Feature: Added export under csv format. [thomasdesvenain]

  • API: Filter exportables by field name by default using excluded_exportables list. [cedricmessiant]

  • API: We can define a dexterity adapter for just one field using field name as adapter name. [thomasdesvenain]

  • Fix: Faceted nav export link ignores results per page criterion. [thomasdesvenain]

  • Fix: Translate sheet title. [thomasdesvenain]

  • Fix: Improve text fields support. [fngaha, thomasdesvenain]

1.1 (2014-06-19)

  • Rename search policy excelexport.search to avoid conflict with ‘search’ view. [thomasdesvenain]

1.0 (2014-06-02)

  • Initial release. [thomasdesvenain]

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

collective_excelexport-2.0.tar.gz (44.0 kB view details)

Uploaded Source

Built Distribution

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

collective_excelexport-2.0-py3-none-any.whl (43.2 kB view details)

Uploaded Python 3

File details

Details for the file collective_excelexport-2.0.tar.gz.

File metadata

  • Download URL: collective_excelexport-2.0.tar.gz
  • Upload date:
  • Size: 44.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for collective_excelexport-2.0.tar.gz
Algorithm Hash digest
SHA256 0155b4831cdd90e27dee8f2c80f34f0c1bcfdfb1b73bc8ac69c0222dc62cb1d1
MD5 6b9d886d78ae59b516bfc22870af495c
BLAKE2b-256 71163670984f8599e3169a358cb9c7ddd6a62a32fac3066bcec360cd3d83e9a4

See more details on using hashes here.

File details

Details for the file collective_excelexport-2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for collective_excelexport-2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 76f2978823f6140660e7a52b5ea61176c71ed471de3be003c5036b9de0b69fa2
MD5 f1a8d235997b21f2db2b6ec952f53234
BLAKE2b-256 01a22693571db3ca302750c82a88ca9eb299d7b258ae07fd7a3836333072f316

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