2017-02-22 2 views
1

Je suis un peu nouveau sur C# et Visual Studio et j'essaie de tracer un graphique basé sur les valeurs d'un fichier csv situé ailleurs. J'ai utilisé la propriété ChartObjects et ChartWizard dans C# pour créer le graphique. Le graphique tracé doit être la plage de colonnes que je fournis, dans l'axe Y et l'axe X doit avoir le numéro de ligne actuel (1,2,3,4 etc.). Cependant, mon graphe par défaut prend l'axe des X pour être la première colonne de mon fichier csv. Il trace correctement si je spécifie une plage pour l'axe X aussi, mais comment puis-je obtenir le numéro de ligne actuel là?Modifier les valeurs de l'axe x du graphique C#

Je suis passé par beaucoup d'articles et de questions même sur Stack Overflow mais aucun n'a semblé aider.

Voici un extrait de mon code:

Microsoft.Office.Interop.Excel.Application xlexcel; 
Microsoft.Office.Interop.Excel.Worksheet xlWorkSheet; 

object misValue = System.Reflection.Missing.Value; 
xlexcel = new Microsoft.Office.Interop.Excel.Application(); 

var xlWorkBooks = xlexcel.Workbooks; 

xlexcel.Visible = false; 

xlWorkBooks.OpenText(@"C:\" + processName + ".csv", misValue, misValue, Microsoft.Office.Interop.Excel.XlTextParsingType.xlDelimited,   Microsoft.Office.Interop.Excel.XlTextQualifier.xlTextQualifierNone, misValue, misValue, misValue, misValue, misValue, misValue, misValue, misValue, misValue, misValue, misValue, misValue, misValue); 

// Set Sheet 1 as the sheet you want to work with 
xlWorkSheet = (Microsoft.Office.Interop.Excel.Worksheet)xlWorkBooks[1].Worksheets.get_Item(1); 

xlWorkSheet.Shapes.AddChart(misValue, misValue, misValue, misValue, misValue).Select(); 

//~~> Make it a Line Chart 
     xlexcel.ActiveChart.ApplyCustomType(Microsoft.Office.Interop.Excel.XlChartType.xlLine); 

//~~> Set the data range 
xlexcel.ActiveChart.SetSourceData(xlWorkSheet.Range["E2:E200"]); 
xlexcel.ActiveChart.ChartWizard(misValue, Title: chartName + " (" + processName + ")", CategoryTitle: "Iterations", ValueTitle: processType); 

Microsoft.Office.Interop.Excel.ChartObjects chartObjects =(Microsoft.Office.Interop.Excel.ChartObjects)(xlWorkSheet.ChartObjects(Type.Missing)); 
foreach (Microsoft.Office.Interop.Excel.ChartObject co in chartObjects) 
{ 
    co.Select(); 
    Microsoft.Office.Interop.Excel.Chart chart = (Microsoft.Office.Interop.Excel.Chart)co.Chart; 
    chart.Export(ConfigurationManager.AppSettings.Get("Charts") + "\\ProcessFiles" + @"\" + chartName + " (" + processName + "of" + processType + ")" + ".png", "PNG", false); 
    co.Delete(); 
} 
xlWorkBooks[1].Close(true, misValue, misValue); 
xlexcel.Quit(); 

Toute orientation serait grandement apprécié. Merci!

+0

que vous voulez afficher dans Excel ou exporter sous forme de fichier image? – imsome1

+0

Je veux l'exporter en tant que fichier image. @ imsome1 – TrishaR

Répondre

0

J'ai essayé votre code et a fait quelques modifications, j'espère que cela fonctionnera

using Excel = Microsoft.Office.Interop.Excel; 

Excel.Application xlApp; 
Excel.Workbook xlWorkBook; 
Excel.Worksheet xlWorkSheet; 

object misValue = System.Reflection.Missing.Value; 
//string appPath = Path.GetDirectoryName(Application.ExecutablePath); 
string fileName = "" + "YOUR_PATH" + "\\Templates\\myCSV.csv"; 

string processName = "test"; 
xlApp = new Excel.Application(); 
xlWorkBook = xlApp.Workbooks.Open(fileName); 
xlWorkSheet = (Excel.Worksheet)xlWorkBook.Worksheets.get_Item(1); 

xlWorkSheet.Shapes.AddChart(misValue, misValue, misValue, misValue, misValue).Select(); 

//~~> Make it a Line Chart 
      xlApp.ActiveChart.ApplyCustomType(Microsoft.Office.Interop.Excel.XlChartType.xlLine); 

//~~> Set the data range 
xlApp.ActiveChart.SetSourceData(xlWorkSheet.Range["B1:B30"]); 
string chartName = "TEST CHART", processType="TEST TYPE"; 
xlApp.ActiveChart.ChartWizard(misValue, Title: chartName + " (" + processName + ")", CategoryTitle: "Iterations", ValueTitle: processType); 

Excel.ChartObjects chartObjects = (Excel.ChartObjects)(xlWorkSheet.ChartObjects(Type.Missing)); 

foreach (Excel.ChartObject co in chartObjects) 
{ 
    co.Select(); 
    Excel.Chart chart = (Excel.Chart)co.Chart; 
    chart.Export("C:\\YOUR_PATH" + @"\" + chart.Name + ".png", "PNG", false); 
} 

xlWorkBook.Close(true, misValue, misValue); 
xlApp.Quit(); 


xlWorkSheet = null; 
xlWorkBook = null; 
xlApp = null; 
releaseObject(xlWorkBook); 
releaseObject(xlWorkSheet); 
releaseObject(xlApp); 

private void releaseObject(object obj) 
{ 
    try 
    { 
    System.Runtime.InteropServices.Marshal.ReleaseComObject(obj); 
    obj = null; 
    } 
    catch (Exception ex) 
    { 
    obj = null; 
    MessageBox.Show(ex.Message); 
    } 
    finally 
    { 
    GC.Collect(); 
    } 
} 
+0

Merci pour votre aide @ imsome1, mais le mien est une application console, donc Application.ExecutablePath ne fonctionne pas. Et à part ça, je reçois toujours le même résultat. – TrishaR

+0

Donnez votre chemin au lieu de Application.ExecutablePath et essayez – imsome1

+0

Oui, j'ai essayé cela. Mais je ne reçois toujours pas la sortie requise. – TrishaR