Solved

Excel, parse strings into columns  from a list of offsets (columns widths) and column names

Posted on 2013-01-30
5
360 Views
Last Modified: 2013-01-30
conceptual ideaHow to parse strings into columns  from a list of offsets (columns widths) and column names.  The rows of text are limited to a hundred or so.  The source string length is <1000 characters,   there are about 40 columns of vary widths.
EE-Excel-parse.xls
0
Comment
Question by:AndyPandy
5 Comments
 
LVL 39

Assisted Solution

by:nutsch
nutsch earned 200 total points
ID: 38837596
On sheet 3, first row, formula starting in A1, copy across

=INDEX(Sheet2!$B$1:$B$40,COLUMN()+1)

On sheet3, second row, formula starting in A2, copy across and down:
=MID(INDEX(Sheet1!$A:$A,ROW()-1),INDEX(Sheet2!$A:$A,MATCH(A$1,Sheet2!$B:$B,0)),INDEX(Sheet2!$A:$A,1+MATCH(A$1,Sheet2!$B:$B,0))-INDEX(Sheet2!$A:$A,MATCH(A$1,Sheet2!$B:$B,0)))

Thomas
0
 
LVL 92

Assisted Solution

by:Patrick Matthews
Patrick Matthews earned 50 total points
ID: 38837621
I came up with this while Thomas was posting.  Not the most elegant thing, but it does appear to preempt errors if the source strings are not long enough.

The operative formula goes in Sheet3!A2, and is copied across and down:

=MID(Sheet1!$A2,INDEX(Sheet2!$A:$A,MATCH(A$1,Sheet2!$B:$B,0),1),MAX(0,IFERROR(INDEX(Sheet2!$A:$A,MATCH(B$1,Sheet2!$B:$B,0),1),LEN(Sheet1!$A2)+1)-INDEX(Sheet2!$A:$A,MATCH(A$1,Sheet2!$B:$B,0),1)))

Q-28014774.xlsx
0
 
LVL 50

Accepted Solution

by:
barry houdini earned 250 total points
ID: 38837711
This formula should also work for Sheet3 A2 copied across and down

=MID(LEFT(Sheet1!$A2,MOD(INDEX(Sheet2!$A:$A,MATCH(A$1,Sheet2!$B:$B,0)+1)-1,1000)),SUMIF(Sheet2!$B:$B,A$1,Sheet2!$A:$A),1000)

regards, barry
0
 

Author Closing Comment

by:AndyPandy
ID: 38837990
Thanks, you guys are genius'sssss
Thomas, nice but leaves #value when string too short.
Matt,  #Name?,  perhaps my Excel 2003 doesn't support your solution?
Barry, Nice short and sweet and no error.  Still trying to figure out how it does this.
Thanks guys!
0
 
LVL 92

Expert Comment

by:Patrick Matthews
ID: 38838004
AndyPandy,

Glad to help, and not surprised that once again barry wins the formula derby :)

One of the functions I used, IFERROR, debuted in Excel 2007, so yes, in Excel 2003 and earlier you will get a #NAME error if you use it.

Patrick
0

Featured Post

Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
copy same as above data 18 41
remove extra space at end of cell 12 32
best way to protect an excel questionnaire 5 30
Conditional formatting excel 5 20
Drop Down List with Unique/Distinct Values (Part II - ComboBox or ListBox and Data Validation List Bonus!) David Miller (dlmille) Intro This article focuses on delivering unique, sorted lists to list objects (e.g., ComboBox, ListBox) and Dat…
This tutorial explains how to create a series of drop-down lists that are dependent upon prior selections to guide (“force”) the user to make the correct selection and reduce data errors within Microsoft Excel. Excel 2010 was used for this tutorial;…
The viewer will learn how to use the =DISCRINV command to create a discrete random variable, use this command to model a set of probabilities and outcomes in a Monte Carlo simulation, and learn how to find the standard deviation of a set of probabil…
The viewer will learn how to create a normally distributed random variable in Excel, use a normal distribution to simulate the return on an investment over a period of years, Create a Monte Carlo simulation using a normal random variable, and calcul…

830 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