Solved

Set value in a excel worksheet to equal the length of the previous column in C#

Posted on 2016-10-03
10
94 Views
Last Modified: 2016-11-01
I have a excel workbook with multiple worksheets.I would like to set one column H to be a formula field which is equal to the length of column G. How can I do it using C#.

Thanks,
Aditya
0
Comment
Question by:giveindia
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 5
  • 5
10 Comments
 
LVL 52

Expert Comment

by:Rgonzo1971
ID: 41826149
Hi,

pls try something like this
string s = "=LEN(RC[-1])";
Range rng1 = sheet.get_Range(sheet.Cells[7, 2], (sheet.Cells[7, 2] as Excel.Range).get_End(Excel.XlDirection.xlDown)).Offset[0,1];
rng1.FormulaR1C1 = s;
rng1.Value2 = rng1.Value2;

Open in new window

Regards
0
 

Author Comment

by:giveindia
ID: 41826219
What is value1 and value2 here ?
0
 
LVL 52

Expert Comment

by:Rgonzo1971
ID: 41826222
.Value2 gives you the underlying value of the cell (could be empty, string, error, number (double) or boolean)

.Value gives you the same as .Value2 except if the cell was formatted as currency or date it gives you a VBA currency (which may truncate decimal places) or VBA date.

Using .Value is usually a bad idea because you may not get the real value from the cell, and they are slower than .Value2
0
Office 365 Training for Admins - 7 Day Trial

Learn how to provision tenants, synchronize on-premise Active Directory, implement Single Sign-On, customize Office deployment, and protect your organization with eDiscovery and DLP policies.  Only from Platform Scholar.

 

Author Comment

by:giveindia
ID: 41826238
So the first time the excel is saved the value gets saved correctly. If I open the excel and edit a cell the length column does not get updated.

Thanks,
Aditya
0
 
LVL 52

Expert Comment

by:Rgonzo1971
ID: 41826247
pls try
        string s = "=LEN(RC[-1])";
        Rng1= (Excel.Range)xlWorkSheet.get_Range(xlWorkSheet.Cells[2, 7] as Excel.Range, (xlWorkSheet.Cells[2, 7] as Excel.Range).get_End(Excel.XlDirection.xlDown)).Offset[0,1];
        Rng1.FormulaR1C1 = s;
        Rng1.Value2 = Rng1.Value2;

Open in new window

0
 

Author Comment

by:giveindia
ID: 41826250
THis is the code that I have.
 string s = "=LEN(RC[-1])";
                               Microsoft.Office.Interop.Excel.Range rng1 = wsheet.get_Range(wsheet.Cells[2, 7], (wsheet.Cells[dsMDOID.Tables[0].Rows.Count + 1, 7] as Excel.Range).get_End(Excel.XlDirection.xlDown)).Offset[0, 1];
                               rng1.FormulaR1C1 = s;
                               rng1.Value2 = rng1.Value2;
0
 

Author Comment

by:giveindia
ID: 41826257
Also even if  I have 20 rows in the sheet it seems to apply the formula to around 65K rows.
0
 
LVL 52

Accepted Solution

by:
Rgonzo1971 earned 500 total points
ID: 41826355
then try
  string s = "=LEN(RC[-1])";
Microsoft.Office.Interop.Excel.Range rng1 = wsheet.get_Range(wsheet.Cells[2, 7], (wsheet.Cells[dsMDOID.Tables[0].Rows.Count + 1, 7] as Excel.Range)).Offset[0, 1];
rng1.FormulaR1C1 = s;
rng1.Value2 = rng1.Value2; 

Open in new window

0
 

Author Comment

by:giveindia
ID: 41827435
The code you posted seems to be similar to what I had.

Thanks,
Adittya
0
 
LVL 52

Expert Comment

by:Rgonzo1971
ID: 41827470
get_end removed
0

Featured Post

Get HTML5 Certified

Want to be a web developer? You'll need to know HTML. Prepare for HTML5 certification by enrolling in July's Course of the Month! It's free for Premium Members, Team Accounts, and Qualified Experts.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

This article describes how you can use Custom Document Properties to store settings and other information in your workbook so that they will be available the next time you open the workbook.
Cancel future meetings from user mailboxes in Office 365 using Remove-CalendarEvents
This Micro Tutorial will demonstrate in Microsoft Excel how to add style and sexy appeal to horizontal bar charts.
This Micro Tutorial will demonstrate how to create pivot charts out of a data set. I also added a drop-down menu which allows to choose from different categories in the data set and the chart will automatically update.

636 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question