Краткая информация
Линейчатая диаграмма суммирует и сравнивает категории данных, используя длину линейки для отображения данных.
Более подробно об использовании линейчатых диаграмм в ArcGIS Pro.
Обсуждение
При создании объекта диаграммы необязательные аргументы для конструктора классов должны указываться с помощью имени аргумента; их нельзя указывать по позиции аргумента. См. раздел с примерами кодов, содержащий пример того, как можно задавать аргументы, используя ключевые слова.
Синтаксис
Bar (x, {y}, {aggregation}, {splitCategory}, {multiSeriesDisplay}, {miniChartsPerRow}, {showPreviewChart}, {showMovingAverage}, {movingAveragePeriod}, {rotated}, {title}, {description}, {xTitle}, {yTitle}, {dataSource}, {displaySize})
Параметр | Описание | Тип данных |
x | The field name for the x-axis variable. The field must be a category or a date field. | String |
y | The field names for the numeric fields. Specify a single field name or a list of field names. | String |
aggregation | The statistical calculation applied to values that occur at the same value along the x-axis. Supported statistics are COUNT, SUM, MEAN, MEDIAN, MIN, and MAX. No aggregation means that each value will be plotted on the chart regardless of overlap or recurring values. | String |
splitCategory | A second categorical field that adds a separate series or bar for each unique value in the field. | String |
multiSeriesDisplay | The display type for a bar chart with multiple series. Valid options are sideBySide, stacked, stacked100, and grid. | String |
miniChartsPerRow | Sets the number of mini-charts that will be shown per row. The number of rows will be determined by the total number of series divided by the miniChartsPerRow value. | Integer |
showPreviewChart | Indicates whether the preview chart is visible for grid charts. True displays the preview chart. False hides the preview chart. (Значение по умолчанию — False) | Boolean |
showMovingAverage | Indicates whether the moving average is displayed for temporal bar charts. (Значение по умолчанию — False) | Boolean |
movingAveragePeriod | The size of the moving average period. | Integer |
rotated | Indicates whether bars are viewed vertically or horizontally. Bars display vertically by default. True rotates bars horizontally. False displays bars vertically. (Значение по умолчанию — False) | Boolean |
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 |
xTitle | Sets the title for the x-axis of the chart. | String |
yTitle | Sets the title for the y-axis of the chart. | 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 |
Свойства
Свойство | Описание | Тип данных |
aggregation (чтение и запись) | Статистические вычисления применяются к значениям, которые располагаются по оси x. Поддерживается следующая статистика: COUNT, SUM, MEAN, MEDIAN, MIN и MAX. Отсутствие агрегирования означает, что каждое значение будет нанесено на диаграмму независимо от перекрывающихся или повторяющихся значений. | String |
dataSource (чтение и запись) | Устанавливает источник данных диаграммы. Когда диаграмма экспортируется с использованием метода exportToSVG или отображается в ArcGIS Notebook, источник данных считывается и отображается на диаграмме. К допустимым источникам данных относятся пути к наборам данных, включая локальные наборы данных, пути UNC, URL-адреса служб и объекты arcpy.mp Layer. | Object |
description (чтение и запись) | Задает описание диаграммы. Текст диаграммы отображается внизу вида диаграммы. | String |
displaySize (чтение и запись) | Задает размер диаграммы при экспорте с помощью метода exportToSVG или при отображении в ArcGIS Notebook. Значение должно быть указано как список из двух элементов где первый элемент является шириной диаграммы, а второй - высотой. | List |
legend (чтение и запись) | Задает свойства легенды диаграммы.
| Object |
miniChartsPerRow (чтение и запись) | Задайте число минидиаграмм, которые будут отображаться в строке. Число строк будет определяться количеством серий, деленным на значение miniChartsPerRow. | Integer |
movingAveragePeriod (чтение и запись) | Размер движущегося периода среднего. | Integer |
multiSeriesDisplay (чтение и запись) | Тип отображения для линейчатой диаграммы с несколькими сериями. К доступным опциям относятся sideBySide, stacked, stacked100 и grid: | Boolean |
rotated (чтение и запись) | Указывает, отображаются ли столбцы вертикально или горизонтально. По умолчанию диаграмма отображается вертикально. True поворачивает диаграмму горизонтально. False отображает диаграмму вертикально. | Boolean |
showMovingAverage (чтение и запись) | Указывает, будет ли отображено движущееся среднее на временной линейчатой диаграмме. | Boolean |
showPreviewChart (чтение и запись) | Показывает, будет ли отображаться предварительный просмотр диаграмм в гриде. True - предварительный просмотр диаграммы отображается. False - предварительный просмотр диаграммы скрыт. | Boolean |
splitCategory (чтение и запись) | Поле второй категории, которое добавляет отдельные серии или столбец для каждого уникального значения в поле. | String |
title (чтение и запись) | Задает заголовок диаграммы. Текст заголовка появляется в верхней части вида диаграммы и используется как надпись на панели Содержание на вкладке Содержание на вкладке По отображению. | String |
type (только чтение) | Строковое значение, обозначающее тип диаграммы. | String |
x (чтение и запись) | Имя поля для переменной оси x. Поле должно быть полем категории или даты. | String |
xAxis (чтение и запись) | Задает свойства оси x.
| Object |
y (чтение и запись) | Имена полей для числовых полей. Для этого свойства необходимо задать одно имя поля или список имен полей. | String |
yAxis (чтение и запись) | Задает свойства оси y.
| Object |
Обзор метода
Метод | Описание |
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
url = r"https://services1.arcgis.com/hLJbHVT9ZrDIzK0I/arcgis/rest/services/CrimesChiTheft/FeatureServer/0"
bar = arcpy.charts.Bar(x="BEAT", aggregation="count", title="Chicago Thefts by Beat", dataSource=url)
bar.exportToSVG('bar.svg', width=800, height=500)