你其实并不想改变字体的整个单元格,但您要更改我接受的单元格中的部分文本。 您仍然需要检索单元格范围,然后调整该范围内的字符。这里只是调整第一个单元格的例子。 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;
}
}
你说的智能感知不会让你这么做的意思是什么?有没有错误?如果是,请将它们包括在您的问题中。 –
@KonradGadzina名称在当前上下文中不存在。 – user2330678
这是一个VSTO项目吗? http://msdn.microsoft.com/en-us/library/bhczd18c.aspx –