Pie

Краткая информация

Круговые диаграммы группируют данные в доли для отображения отношений части к целому.

Более подробно о круговых диаграммах в ArcGIS Pro

Обсуждение

При создании объекта диаграммы необязательные аргументы для конструктора классов должны указываться с помощью имени аргумента; их нельзя указывать по позиции аргумента. См. раздел с примерами кодов, содержащий пример того, как можно задавать аргументы, используя ключевые слова.

Синтаксис

 Pie ({categoryField}, {numberFields}, {groupingPercent}, {donutSize}, {sort}, {showDataLabels}, {dataLabelsDisplay}, {title}, {description}, {dataSource}, {displaySize})
ПараметрОписаниеТип данных
categoryField

The field name for the category variable.

String
numberFields

The field names for the numeric field or fields. Specify a single field name or a list of field names.

String
groupingPercent

The percentage threshold for grouping smaller slices into a single Other category. Expects an integer between 0 and 100 that represents the maximum percentage value for determining which slices are grouped into the Other category.

Integer
donutSize

The size of the hole when displaying a pie chart as a donut. Expects an integer between 0 and 100 that represents the size of the hole as a percentage relative to the total size of the pie.

Integer
sort

The sorting method applied to the chart. Valid options are LABEL_CLOCKWISE, LABEL_COUNTERCLOCKWISE, VALUE_CLOCKWISE, and VALUE_COUNTERCLOCKWISE.

String
showDataLabels

Indicates whether data labels are displayed. True displays data labels, and False hides data labels.

Boolean
dataLabelsDisplay

The format of the data labels. Valid options are VALUE, PERCENTAGE, and PERCENTAGE_AND_VALUE.

String
title

Sets the title of the chart. The title text appears at the top of the chart view and is used as the label for the chart in the Contents pane.

String
description

Sets the description of the chart. The description text appears at the bottom of the chart view.

String
dataSource

Sets the data source of the chart. When a chart is exported using the exportToSVG method or displayed in an ArcGIS Notebook, the data source is read and rendered on the chart. Valid data sources include paths to datasets, including local datasets, UNC paths, and service URLs, and arcpy.mp Layer objects.

Object
displaySize
[displaySize,...]

Sets the size of the chart when exported using the exportToSVG method or displayed in an ArcGIS Notebook. The value must be specified as a two-item list, where the first item is the width of the chart and the second item is the height of the chart.

List

Свойства

СвойствоОписаниеТип данных
categoryField
(чтение и запись)

Имя поля для переменной категории.

String
dataLabelsDisplay
(чтение и запись)

Формат подписей данных. Допустимые опции – это VALUE, PERCENTAGE и PERCENTAGE_AND_VALUE.

String
dataSource
(чтение и запись)

Устанавливает источник данных диаграммы. Когда диаграмма экспортируется с использованием метода exportToSVG или отображается в ArcGIS Notebook, источник данных считывается и отображается на диаграмме. К допустимым источникам данных относятся пути к наборам данных, включая локальные наборы данных, пути UNC, URL-адреса служб и объекты arcpy.mp Layer.

Object
description
(чтение и запись)

Задает описание диаграммы. Текст диаграммы отображается внизу вида диаграммы.

String
displaySize
(чтение и запись)

Задает размер диаграммы при экспорте с помощью метода exportToSVG или при отображении в ArcGIS Notebook. Значение должно быть указано как список из двух элементов где первый элемент является шириной диаграммы, а второй - высотой.

List
donutSize
(чтение и запись)

Размер отверстия при отображении круговой диаграммы в виде кольца. Ожидает целое число от 0 до 100, представляющее размер отверстия в процентах по отношению к общему размеру круговой диаграммы.

Integer
groupingPercent
(чтение и запись)

Процентный порог для группировки меньших фрагментов в одну категорию Other. Ожидает целое число от 0 до 100, представляющее максимальное процентное значение для определения того, какие фрагменты будут сгруппированы в категорию Other.

Integer
legend
(чтение и запись)

Задает свойства легенды диаграммы.

  • visible – показывает, отображается ли легенда в виде диаграммы. True – отображает легенду. False - скрывает легенду.
  • title – заголовок, отображаемый для легенды.
Object
numberFields
(чтение и запись)

Имена полей для числовых полей. Для этого свойства необходимо задать одно имя поля или список имен полей.

String
showDataLabels
(чтение и запись)

Указывает, будут ли отображены подписи к данным. True отображает подписи данных, а False скрывает подписи данных.

Boolean
sort
(чтение и запись)

Метод сортировки, примененный к круговой диаграмме. Допустимые опции: LABEL_CLOCKWISE, LABEL_COUNTERCLOCKWISE, VALUE_CLOCKWISE и VALUE_COUNTERCLOCKWISE.

String
title
(чтение и запись)

Задает заголовок диаграммы. Текст заголовка появляется в верхней части вида диаграммы и используется как надпись на панели Содержание на вкладке По отображению Содержание на вкладке По отображению.

String
type
(только чтение)

Строковое значение, обозначающее тип диаграммы.

String

Обзор метода

МетодОписание
addToLayer (layer_or_layerfile)

Добавление объекта диаграммы в слой или в автономную таблицу.

exportToSVG (path, width, height)

Экспортирует диаграмму в формат SVG.

updateChart ()

Обновляет свойства диаграммы для синхронизации изменений между объектом и диаграммой, предварительно добавленной к слою.

Методы

addToLayer (layer_or_layerfile)
ПараметрОписаниеТип данных
layer_or_layerfile

The chart will be added to the target object. The layer_or_layerfile argument can be a Layer or a Table object.

Object

Обычно последним шагом после задания свойств диаграммы является добавление объекта диаграммы в слой или в таблицу, с помощью метода addToLayer.

Добавьте диаграмму к существующему слою.

import arcpy

aprx = arcpy.mp.ArcGISProject("current")
map = aprx.listMaps()[0]
censusLayer = map.listLayers('Census Block Groups')[0]

# Add chart object to a layer
chart.addToLayer(censusLayer)
exportToSVG (path, width, height)
ПараметрОписаниеТип данных
path

The path where the chart will be exported in SVG format.

String
width

The width of the output graphic.

Integer
height

The height of the output graphic.

Integer

В некоторых случаях вам может понадобиться сохранить диаграмму в графический формат, который можно совместно использовать и просматривать вне ArcGIS Pro. Преимуществом экспорта в формат SVG является то, что графические элементы и текст сохраняются, как векторные объекты, каждый из которых можно изменять в программе, работающей с векторной графикой. Размер графики SVG также можно изменить на любой другой без потери качества.

Экспортируйте диаграмму, содержащую источник данных слоя проекта в файл .svg.

import arcpy

aprx = arcpy.mp.ArcGISProject('current')
censusLayer = aprx.listMaps()[0].listLayers('Census Block Groups')[0]

# Set data source of chart object to a layer within current project
chart.dataSource = censusLayer

# Save the chart to file with dimensions width=500, height=500
chart.exportToSVG('populationByState.svg', 500, 500)

Экспортируйте диаграмму, содержащую источник данных сервиса объектов в файл .svg.


featureServiceURL = r'https://services1.arcgis.com/hLJbHVT9ZrDIzK0I/arcgis/rest/services/CrimesChiTheft/FeatureServer/0'

# Set data source of chart object to a feature service URL
chart.dataSource = featureServiceURL

# Save the chart to file with dimensions width=800, height=600
chart.exportToSVG('theftsPerBeat.svg', 800, 600)
updateChart ()

Обычно последним шагом после задания свойств диаграммы является добавление объекта диаграммы в слой с помощью метода addToLayer.

Для дальнейшего изменения свойств диаграммы можно изменить параметры исходной диаграммы, вместо создания новой. Затем можно использовать метод updateChart для синхронизации любых изменений с диаграммой, добавленной к слою. Это позволит отображаться изменениям, внесенным вами, на панели свойств Диаграмма и в виде диаграммы.

Используйте метод updateChart для синхронизации изменений свойств диаграммы в слое.


chart.addToLayer(myLayer)

# Further modification is necessary
chart.description = "Data from the U.S. Census Bureau"
chart.updateChart()

Пример кода

Создайте круговую диаграмму из слоя и экспортируйте диаграмму в файл .svg.


import arcpy
lyr = arcpy.mp.ArcGISProject("current").activeMap.listLayers("nyc_noise_complaints")[0]
pie = arcpy.charts.Pie(categoryField="Complaint_Type", title="Noise Complaints by Type", dataSource=lyr)
pie.exportToSVG('pie.svg', width=1000, height=800)