2014-02-18 52 views
0

如何使用C#在Excel单元格中创建和设置样式?使用C#在Excel单元格中创建和设置样式?

我想写与ST像“月1日”作为。 我会使用字符串格式而不是日期格式。

我试过http://msdn.microsoft.com/en-us/library/f1hh9fza.aspx,但得到了一个在当前上下文错误中不存在名称'Globals'。我已经添加了程序集Microsoft.Office.Interlop.Excel。我是否错过任何其他程序集?

Excel.Style style = Globals.ThisWorkbook.Styles.Add("NewStyle"); 
+1

你说的智能感知不会让你这么做的意思是什么?有没有错误?如果是,请将它们包括在您的问题中。 –

+0

@KonradGadzina名称在当前上下文中不存在。 – user2330678

+0

这是一个VSTO项目吗? http://msdn.microsoft.com/en-us/library/bhczd18c.aspx –

回答

2

你其实并不想改变字体的整个单元格,但您要更改我接受的单元格中的部分文本。 您仍然需要检索单元格范围,然后调整该范围内的字符。这里只是调整第一个单元格的例子。 A1。

如果你想改变整个单元格范围是上标,它会这样做 currentRange.Font.Superscript = true;

void Main() 
{ 
     var app = new Application(); 
     app.Visible = true; 
     var workbook = app.Workbooks.Add(1); 

     Sheets excelSheets = workbook.Worksheets; 
     string currentSheet = "Sheet1"; 
     Worksheet worksheet1 = (Worksheet)excelSheets.get_Item(currentSheet); 

     worksheet1.Cells[1, 1] = "April 1st"; 
     worksheet1.Cells[1, 2] = "April 2nd"; 
     worksheet1.Cells[1, 3] = "April 3rd"; 
     worksheet1.Cells[1, 4] = "April 4th"; 

     // fill in the starting and ending range programmatically this is just an example. 
     string startRange = "A1"; 
     string endRange = "A1"; 
     Range currentRange = worksheet1.get_Range(startRange , endRange); 

     var text = currentRange.Text.ToString(); 
     int length = text.Length; 
     int index = 0; 
     if(text.Contains("st")) 
     { 
      index =text.IndexOf("st"); 
     } 
     //The other checks for "nd", "rd", "th" obviously check to see a # precedes these. 

     if(index > 0) 
     {   
      currentRange.get_Characters(index+1, 2).Font.Superscript = true;    
     }   
} 
1

正如您所链接到的状态MSDN文章:

适用于:本主题中的信息适用于文档级 项目和应用程序级项目为Office 2013和Office 请参阅按Office应用程序和项目类型提供的功能。

要使用Globals类,您必须创建Office项目。对于另一个参考,您可以检查this question有关创建Office加载项:

Globals.ThisAddin.Application只能用于在VSTO外接

+0

我是否需要添加一个新的Office应用程序或VSTO项目,以便在上例中解释的类型的excel中使用上标和下标? – user2330678

+0

@ user2951819我看到一些不带'Globals'的上标但带有一些外部库的例子 - http://www.aspose.com/docs/display/cellsnet/Apply+Superscript++and++Subscript+Effects+on +字体目前我无法检查它是否适用于基本的Office Interop。 –

+0

我无法使用它们。我将需要一些库或mabe另一种应用程序类型。 – user2330678

相关问题