Проблема типа осей Powershell Chart - PullRequest
0 голосов
/ 29 апреля 2018

ищет помощи.

Когда я рисую диаграмму, используя System.Windows.Forms.DataVisualization.Charting.Chart Ось Y отформатирована в научной нотации - как предполагается, до десятичной, которую я желаю. У меня есть простой набор данных, содержащийся в одной $ hashtable.

    # data source
       $datasource = @{London = 0.000000512; Berlin = 0.000000520; Madrid = 0.000000519; Rome = 0.000000518; Paris = 0.000000503}

    foreach ($h in $datasource.Keys) 
        {
        echo ( "${h} $([decimal]$datasource.Item($h))"  )
        $chart1.Series["Price"].Points.addxy( $h ,[decimal]$datasource.Item($h))   
        }

Когда график создается, ось Y выглядит так:

Фрагмент диаграммы

Эти значения записываются на консоль в правильном формате, как я могу добавить их в серию диаграмм в виде типа Десятичный / Предотвратить серию, отображающую их в научной нотации?

Заранее спасибо.

1 Ответ

0 голосов
/ 29 апреля 2018

Вы можете использовать строку пользовательского числового формата для оси Y, например:

$chartarea.AxisY.LabelStyle.Format = "##.###############";

Вот более полный пример:

Add-Type -AssemblyName System.Windows.Forms 
Add-Type -AssemblyName System.Windows.Forms.DataVisualization 
$chart1 = New-object System.Windows.Forms.DataVisualization.Charting.Chart 

$chart1.Width = 400
$chart1.Height = 400

$chartarea = New-Object System.Windows.Forms.DataVisualization.Charting.ChartArea
$chartarea.AxisY.LabelStyle.Format = "##.###############";
$chartarea.AxisY.Minimum = 0.0000005
$chartarea.AxisY.Maximum = 0.00000052

$chart1.ChartAreas.Add($chartarea) 

$chart1.Titles.Add("The Price") | Out-Null
$chart1.Series.Add("Price") | Out-Null 
$chart1.Series[0].ChartType = [System.Windows.Forms.DataVisualization.Charting.SeriesChartType]::Line
$chart1.Series[0].YValueType = [System.Windows.Forms.DataVisualization.Charting.ChartValueType]::Double

# data source
$datasource = @{London = 0.000000512; Berlin = 0.000000520; Madrid = 0.000000519; Rome = 0.000000518; Paris = 0.000000503}

foreach ($h in $datasource.Keys) 
{
    echo ( "${h} $([decimal]$datasource.Item($h))"  )
    $chart1.Series["Price"].Points.addxy( $h ,[decimal]$datasource.Item($h))   
}

$chart1.Anchor = [System.Windows.Forms.AnchorStyles]::Bottom -bor `
    [System.Windows.Forms.AnchorStyles]::Left -bor `
    [System.Windows.Forms.AnchorStyles]::Right -bor `
    [System.Windows.Forms.AnchorStyles]::Top 

$form = New-Object Windows.Forms.Form
$form.Width = 450
$form.Height = 450
$form.Controls.Add($chart1)
$form.ShowDialog()
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...