Jump to content

Extensão:DynamicPageList4

From mediawiki.org
This page is a translated version of the page Extension:DynamicPageList4 and the translation is 21% complete.
Outdated translations are marked like this.
Manual de extensões do MediaWiki
DynamicPageList4
Estado da versão: estável
Implementação Marcação , Função de análise sintática
Descrição Create lists of other articles based on their category, namespace, title, references or template usage and include contents or arguments of template calls of those articles into your page.
Autor(es) Universal Omega
Última versão 4.0.5 (2026-02-05)
MediaWiki 1.44.0+
Modifica o banco
de dados
Sim
Composer universal-omega/dynamic-page-list4
  • $wgDPLQueryCacheTime
  • $wgDPLFunctionalRichness
  • $wgDPLAllowUnlimitedCategories
  • $wgDPLCategoryStyleListCutoff
  • $wgDPLAllowedNamespaces
  • $wgDPLMaxCategoryCount
  • $wgDPLMaxResultCount
  • $wgDPLRunFromProtectedPagesOnly
  • $wgDPLRecursiveTagParse
  • $wgDPLAllowUnlimitedResults
  • $wgDPLRecursivePreprocess
  • $wgDPLMaxQueryTime
  • $wgDPLMinCategoryCount
  • $wgDPLOverrideParameterDefaults
  • $wgDPLAlwaysCacheResults
License GNU General Public License 3.0 or later
Download
Exemplo DynamicPageList4 Manual
Para traduzir a extensão DynamicPageList4, verifique sua disponibilidade no translatewiki.net
This is a continuation/rewrite of Extension:DynamicPageList3 . It is a fully reworked code base, with significant code and database speed improvements, and is designed to be fully backward compatible with previous versions. It fixes numerous bugs and adds more features then previous versions and makes the extension more maintainable and secure by converting to MediaWiki's SelectQueryBuilder for example.

A extensão DynamicPageList4 é uma ferramenta de relatório para MediaWiki, listando membros da categoria e interseções com vários formatos e detalhes. Para obter a documentação completa, consulte o [[1]].

Quando chamado com um conjunto básico de parâmetros de seleção, o DynamicPageList4 exibe uma lista de páginas em uma ou mais categorias. As seleções também podem ser baseadas em fatores como autor, namespace, data, padrão de nome, uso de modelos ou referências a outros artigos. A saída assume uma variedade de formas, algumas das quais incorporam elementos de artigos selecionados.

Esta extensão é chamada com a função do analisador {{#dpl: .... }} ou a tag do analisador ‎<DPL>. Uma implementação compatível com a Wikimedia de certos recursos pode ser chamada com ‎<DynamicPageList>.

Pesquisas complexas podem resultar em consultas de banco de dados caras do ponto de vista computacional. No entanto, por padrão, todas as saídas são armazenadas em cache por um período de uma hora para reduzir a necessidade de executar novamente a consulta a cada carregamento de página. A página de manual Outros Parâmetros contém informações sobre os parâmetros que podem ser usados para desabilitar o cache e permitir atualizações instantâneas.

Manual and Complete Documentation
DynamicPageList4 manual
Código Fonte
Source code
Bugs e Solicitações de Recursos no GitHub
Issue and request tracker

Instalação

Configuração

These are DPL4's configuration settings, along with their default values.

To change them, ensure they are defined before including the extension on the wiki.

Configuração Padrão Descrição
$wgDPLAllowedNamespaces [] By default, all existing namespaces are used when DPL4 initializes. Customize this setting with an array of namespace constants to restrict DPL4 to work only in those namespaces.
$wgDPLAllowUnlimitedCategories false Set this to true to ignore $wgDPLMaxCategoryCount and allow unlimited categories. Please note that large amounts of categories in a query can slow down or crash servers.
$wgDPLAllowUnlimitedResults false Set this to true to ignore $wgDPLMaxResultCount and allow unlimited results. Please note that large result sets may result in slow or failed page loads.
$wgDPLAlwaysCacheResults false Set this to true to ignore 'allowcachedresults' and always enable the parser cache.
$wgDPLCategoryStyleListCutoff 6 Maximum number of items in a category list before being cut off.
$wgDPLFunctionalRichness 3 Set the level of parameters available to end users.
$wgDPLMaxCategoryCount 8 Maximum number of categories to allow in queries.
$wgDPLMaxQueryTime 10000 Maximum allowed time for database queries in milliseconds.
$wgDPLMaxResultCount 500 Maximum number of results to return from a query.
$wgDPLMinCategoryCount 0 Minimum number of categories to allow in queries.
$wgDPLOverrideParameterDefaults [] An associative array of parameter names and their override values. These values replace the default parameter values defined in ParametersData, but only if the current defaults differ.
$wgDPLQueryCacheTime 0 Configure query cache time. The query cache cannot be purged. Suggested value between 30 to 600.
$wgDPLRecursivePreprocess true Use Parser::recursivePreprocess() to improve performance by preserving the internal cache, reducing redundant template parsing.
$wgDPLRecursiveTagParse false Do recursive tag parsing on ‎<dpl> parser tags converting tags and functions such as magic words like {{PAGENAME}}. This is similar to the {{#dpl}} parser function call, but may not work the same in all cases.
$wgDPLRunFromProtectedPagesOnly false Set this to true to allow DPL4 to run from protected pages only. This is recommended if wiki administrators are having issues with malicious users creating computationally intensive queries.

The global variable $wgNonincludableNamespaces is automatically respected by DynamicPageList4.

It will prevent the contents of the listed namespaces from appearing in DynamicPageList4's output.

$wgDPLMaxResultCount is a LIMIT on the SQL query itself. Some DynamicPageList4 query parameters like includematch are applied after the SQL query, however, so results here may easily be misleading.

Riqueza Funcional

DynamicPageList4 has many features unlocked based on the maximum functional richness level.

Some can cause high CPU or database load and should be used sparingly.

  • $wgDPLFunctionalRichness = 0equivalent to Wikimedia's DynamicPageList (Intersection)
  • $wgDPLFunctionalRichness = 1adds additional formatting parameters
  • $wgDPLFunctionalRichness = 2adds performance equivalent features for templates and pagelinks
  • $wgDPLFunctionalRichness = 3allows more-expensive page inclusion features and regular expression queries
  • $wgDPLFunctionalRichness = 4not recommended for public websites. Includes debugging parameters for testing and development.

Uso

Funcionalidade DPL Estendida

Extended dynamic page lists are invoked by using the parser function {{#dpl: .... }}, or the parser extension tag ‎<DPL>...‎</DPL>.

See Manual - General Usage and Invocation Syntax and DPL:Parameters: Criteria for Page Selection

Compatibilidade com versões anteriores

Functionality compatible with Wikimedia's DynamicPageList extension can be invoked with ‎<DynamicPageList>...‎</DynamicPageList>.

Further information can be found on the Compatibility manual page.


Filosofia de uso e visão geral

With the assumption there are some articles written about countries those articles will typically have three things in common:

  • They will belong to a common category
  • They will have a similar chapter structure, i.e., they will contain paragraphs named 'Religion' or 'History'
  • They will use a template which is used to present highly structured short data items ('Capital', 'Inhabitants', ..) nicely (e.g., as a wikitable)

Generate a report based on countries

If there was a need to assemble a report of what countries practice a certain religion, this could be easily done with the category and linksto parameters.

{{#dpl:
category=countries
|linksto=Pastafarianism
}}

With DynamicPageList4, one could:

  • Generate a list of all those articles (or a random sample)
  • Show metadata of the articles (popularity, date of last update, ..)
  • Show one or more chapters of the articles ('transclude' content)
  • Show parameter values which are passed to the common template
  • Order articles appropriately
  • Present the result in a sortable table
  • Generate multiple column output

Quais etapas são necessárias?

Find the articles you want to list:

  • Select by a logical combination (AND, OR, NOT) of categories
  • Specify a range for the number of categories the article must be assigned to
  • Select by a logical combination (AND, OR, NOT) of namespaces
  • Define a pattern which must match the article's name
  • Name a page to which the article must or must not link
  • Name a template which the article must or must not use
  • Name a text pattern that must occur within external links from a page
  • Exclude or include redirections
  • Restrict your search to stable pages or quality pages ("flagged revisions")
  • Use other criteria for selection like the author, date of last change, etc.
  • Define regular expressions to match the contents of pages you want to include

Order the result list of articles according to

  • Article title
  • Article display title
  • Article size
  • Date of last change
  • Last user to make an edit

Define attributes you want to see

  • Article name
  • Article namespace
  • Article size
  • Date of last change
  • Date of last access
  • Last user to make an edit

Define contents you want to show

  • Whole article
  • Contents of certain sections (identified by headings)
  • Text portions (defined by special marker tags in the article)
  • Values of template calls
  • Use a custom template to show output

Define the output format

  • Specify header and footer for the default output
  • Use ordered list, unordered list
  • Use tables
  • Format table fields individually by applying templates to their content
  • Use category style listing
  • Truncate title or contents to a certain maximum length
  • Add a link to the article or one or more of its sections

Considerações

Desempenho

DPL4's code execution and database access are typically fast for category and article lookups.

However, using loose LIKE and REGEXP match parameters and/or requesting large data sets can result in long database access times.

Parser time should also be taken into consideration.

For example, having the query of image results go into a template that displays them will result in a parser media transform for each one.

This can quickly eat up 2MBs of RAM per media transform.

It is recommended to configure the following configuration options:

  • $wgDPLMaxQueryTime']allows configuration of the max execution length for queries, in milliseconds
  • $wgDPLQueryCacheTimeallows configuration of the query cache. It also supports PoolCounter to limit query concurrency.

Ver também

Leitura adicional

DynamicPageList4 can do much more than we can explain here.

A complete manual is available with full parameter documentation.