Line

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

Диаграммы-графики позволяют вам визуализировать изменения в непрерывном диапазоне, например, времени или расстояния. Визуализация изменений с помощью графика позволяет одновременно отображать общий тренд, а также одновременно сравнивать несколько трендов.

Более подробно о диаграммах-графиках в ArcGIS Pro.

Обсуждение

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

Синтаксис

 Line (x, {y}, {splitCategory}, {multiSeriesDisplay}, {miniChartsPerRow}, {showPreviewChart}, {aggregation}, {timeIntervalUnits}, {timeIntervalSize}, {timeAggregationType}, {trimIncompleteTimeInterval}, {nullPolicy}, {rotated}, {title}, {description}, {xTitle}, {yTitle}, {dataSource}, {displaySize})
ПараметрОписаниеТип данных
x

The field name for the x-axis variable. The field must be a numeric or date field.

String
y

The field name or names for the y-axis variables. The value must be a numeric field or a list of numeric fields.

String
splitCategory

A categorical field that adds a separate series or line for each unique value in the field.

String
multiSeriesDisplay

Specifies the display type for a line chart with multiple series.

  • singleChartAll series are displayed in a single chart.
  • gridThe series are displayed as a grid of miniplots.
String
miniChartsPerRow

The number of minicharts 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

Specifies whether the preview chart will be displayed for grid charts.

  • TrueThe preview chart will be displayed.
  • FalseThe preview chart will not be displayed.

(Значение по умолчанию — False)

Boolean
aggregation

Specifies the statistical calculation that is applied to values aggregated into each temporal bin.

  • <None>Each value is plotted on the chart regardless of overlap or recurring values.
  • COUNTThe total number of records is identified and applied.
  • SUMThe sum of all values is calculated and applied.
  • MEANThe mean of all values is calculated and applied.
  • MEDIANThe median of all values is identified and applied.
  • MINThe minimum value is identified and applied.
  • MAXThe maximum value is identified and applied.
String
timeIntervalUnits

Specifies the time unit that corresponds to the timeIntervalSize.

  • SECONDSThe time unit is seconds.
  • MINUTESThe time unit is minutes.
  • HOURSThe time unit is hours.
  • DAYSThe time unit is days.
  • WEEKSThe time unit is weeks.
  • MONTHSThe time unit is months.
  • YEARSThe time unit is years.
String
timeIntervalSize

The span of time that is binned or aggregated together. This argument must be used in conjunction with timeIntervalUnits.

String
timeAggregationType

Specifies the time interval alignment type.

  • equalIntervalsFromStartTimeThe time interval is aligned to the start date.
  • equalIntervalsFromEndTimeThe time interval is aligned to the end date.
String
trimIncompleteTimeInterval

Specifies whether incomplete time intervals at the start or end of the data span (depending on the timeAggregationType value) are removed (trimmed) from the chart. Incomplete intervals on a chart can cause misleading results in which the period in question is underreported or overreported due to a different amount of time in the interval.

  • TrueIncomplete intervals are removed.
  • FalseIncomplete intervals are not removed.
String
nullPolicy

Specifies how summarized bins returning a null value are displayed.

  • nullMissing values are treated as null.
  • zeroMissing values are treated as zero.
  • interpolateInterpolation is used to fill missing values.
String
rotated

Specifies whether lines are displayed horizontally or vertically.

  • TrueLines are displayed vertically.
  • FalseLines are displayed horizontally.

(Значение по умолчанию — False)

Boolean
title

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

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

String
xTitle

The title of the x-axis of the chart.

String
yTitle

The title of the y-axis of the chart.

String
dataSource

The data source of the chart. When a chart is exported using the exportToSVG method or displayed in an ArcGIS Notebook, the data source will be read and rendered on the chart. Valid data sources include the following:

  • Paths to datasets, including local datasets, UNC paths, and service URLs
  • Arrow table objects
  • Layer objects

Object
displaySize
[displaySize,...]

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 in which the first item is the width of the chart and the second item is the height of the chart.

List

Свойства

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

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

  • <None>Каждое значение будет нанесено на диаграмму независимо от перекрывающихся или повторяющихся значений.
  • COUNTОбщее количество записей определяется и применяется.
  • SUMСумма всех значений вычисляется и применяется.
  • MEANСреднее значение вычисляется и применяется.
  • MEDIANМедиана всех значений вычисляется и применяется.
  • MINМинимальное значение вычисляется и применяется.
  • MAXМаксимальное значение вычисляется и применяется.
String
dataSource
(чтение и запись)

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

  • Пути к наборам данных, включая локальные наборы данных, пути UNC, URL-адреса сервисов
  • Объекты таблицы Arrow
  • Объекты Layer.

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

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

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

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

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

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

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

Число минидиаграмм, которые будут отображаться в строке. Число строк будет определяться количеством серий, деленным на значение miniChartsPerRow.

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

Задает тип отображения для линейной диаграммы с несколькими сериями.

  • singleChartВсе серии отображаются в виде одной диаграммы.
  • gridСерии отображаются в виде сетки мини-диаграмм.
String
nullPolicy
(чтение и запись)

Определяет, как отображаются суммированные ячейки, возвращающие значение null.

  • nullОтсутствующие значения считаются, как null.
  • zeroОтсутствующие значения считаются равными нулю.
  • interpolateДля заполнения отсутствующих значений используется интерполяция.
String
rotated
(чтение и запись)

Указывает, отображается ли диаграмма вертикально или горизонтально.

  • TrueДиаграмма отображается горизонтально.
  • FalseДиаграмма отображается вертикально.
Boolean
showPreviewChart
(чтение и запись)

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

  • TrueПредварительный просмотр диаграммы отображается.
  • FalseПредварительный просмотр диаграммы не отображается.
Boolean
splitCategory
(чтение и запись)

Поле категории, которое добавляет отдельные серии или линию для каждого уникального значения в поле.

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

Задает имя темы, применяемой к диаграмме.

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

Задает тип выравнивания временного интервала.

  • equalIntervalsFromStartTimeВременной интервал соответствует дате начала.
  • equalIntervalsFromEndTimeВременной интервал соответствует дате окончания.
String
timeIntervalSize
(чтение и запись)

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

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

Задает единицу времени для значения timeIntervalSize.

  • SECONDSЕдиницы измерения времени - секунды.
  • MINUTESЕдиницы измерения времени - минуты.
  • HOURSЕдиницы измерения времени - часы.
  • DAYSЕдиницы измерения времени - дни.
  • WEEKSЕдиницы измерения времени - недели.
  • MONTHSЕдиницы измерения времени - месяцы.
  • YEARSЕдиницы измерения времени - годы.
String
title
(чтение и запись)

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

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

Определяет, будут ли незавершенные временные интервалы в начале или в конце интервала данных (в зависимости от значения timeAggregationType) удалены из диаграммы. Незавершенные интервалы на диаграмме могут привести к ошибочным результатам, в которых рассматриваемый период меньше или больше указанного из-за различного количества времени в интервале.

  • TrueНезавершенные интервалы удаляются.
  • FalseНезавершенные интервалы не удаляются.
String
type
(только чтение)

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

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

Имя поля для переменной оси x. Поле должно быть числовым или полем даты.

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

Задает свойства оси x.

  • field - имя поля для переменной оси x. Поле должно быть числовым или полем даты.
  • logarithmic – определяет, является ли ось логарифмической. True отображает логарифмическую ось. False отображает линейную ось.
  • maximum – максимальная граница оси.
  • minimum – минимальная граница оси.
  • sort - это свойство не поддерживается для класса Line.
  • title – подпись оси, отображаемая в диаграмме.
Object
y
(чтение и запись)

Имена полей для числовых полей. Укажите одно имя поля или список имен полей.

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

Задает свойства оси y.

  • field - имена полей для числовых полей. Укажите одно имя поля или список имен полей.
  • invert — указывает, будет ли ось инвертирована. True инвертирует ось, а False не инвертирует ось.
  • logarithmic – определяет, является ли ось логарифмической. True отображает логарифмическую ось. False отображает линейную ось.
  • maximum – максимальная граница оси.
  • minimum – минимальная граница оси.
  • sort - это свойство не поддерживается для класса Line.
  • title – подпись оси, отображаемая в диаграмме.
  • useAdaptiveBounds – определяет, отображается ли сетчатая диаграмма с адаптивными или фиксированными границами осей. True - оси с адаптивными границами. False - оси с фиксированными границами.
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()

Пример кода

Создайте диаграмму-график и добавьте ее к слою в текущем проекте.

import arcpy

lyr = arcpy.mp.ArcGISProject("current").listMaps()[0].listLayers()[0]
chart = arcpy.charts.Line(x="date", y="aqi", aggregation="mean")
chart.addToLayer(lyr)