Excel formula to rearrange the cell contents ENG/DEF/001/14 to ENG/DEF/14/001

HelenL

New Member
Joined
Nov 17, 2008
Messages
26
Excel formula to rearrange the cell contents ENG/DEF/001/14 to ENG/DEF/14/001

Help appreciated - completely lost! :LOL:
 

Some videos you may like

Excel Facts

Formula for Yesterday
Name Manager, New Name. Yesterday =TODAY()-1. OK. Then, use =YESTERDAY in any cell. Tomorrow could be =TODAY()+1.

sandy666

Well-known Member
Joined
Oct 24, 2015
Messages
4,682
with PowerQuery (Get&Transform)

rawresult
ENG/DEF/001/14ENG/DEF/14/001

Code:
[SIZE=1]// Table1
let
    Source = Excel.CurrentWorkbook(){[Name="Table1"]}[Content],
    Split = Table.SplitColumn(Source, "raw", Splitter.SplitTextByAnyDelimiter({"/"}, QuoteStyle.Csv)),
    Merge = Table.CombineColumns(Split,{"raw.1", "raw.2", "raw.4", "raw.3"},Combiner.CombineTextByDelimiter("/", QuoteStyle.None),"result")
in
    Merge[/SIZE]
 
Last edited:

ClaireS

Board Regular
Joined
Jul 29, 2013
Messages
136
Or just [FONT=Verdana,Arial,Tahoma,Calibri,Geneva,sans-serif]=LEFT(A1,8)&MID(A1,13,2)&"/"&MID(A1,9,3) where A1 is the cell containing your source string.[/FONT]
 

kweaver

Well-known Member
Joined
May 8, 2018
Messages
927
Office Version
365, 2010
With your original text in A1, here's an ugly formula for B1 that will make the switch:

Code:
=LEFT(A1,FIND(CHAR(1),SUBSTITUTE(A1,"/",CHAR(1),2)))&RIGHT(A1,LEN(A1)-FIND(CHAR(1),SUBSTITUTE(A1,"/",CHAR(1),3)))&MID(A1,FIND(CHAR(1),SUBSTITUTE(A1,"/",CHAR(1),2)),FIND(CHAR(1),SUBSTITUTE(A1,"/",CHAR(1),3))-FIND(CHAR(1),SUBSTITUTE(A1,"/",CHAR(1),2)))
This one assumes the length of the characters between the slashes might vary.
 
Last edited:

Rick Rothstein

MrExcel MVP
Joined
Apr 18, 2011
Messages
35,652
Office Version
2010
Platform
Windows
Excel formula to rearrange the cell contents ENG/DEF/001/14 to ENG/DEF/14/001
There are several ways to do this, some way more efficient than others but which might depend on the structure of your data, so I have some questions.

1) Is this for a single cell (which one) or a column of cells (which column and start row)?

2) Is the first field (the ENG) always 3 characters long?

3) Is the second field (the DEF) always 3 characters long?

4) Is the third field (the 001) always 3 digits long?

5) Is the last field (the 14) always 2 digits long (meaning single digit numbers have leading zeros in order to make it 2 digits long)?

6) Are you trying to physically change your data to this revised format directly within their cells (so if your example was in cell A1, the revised text would end up in cell A1)?
 

HelenL

New Member
Joined
Nov 17, 2008
Messages
26
1) single cell A1 Row 2 but will pull the formula down through the rest
2) yes
3) yes
4) yes
5)yes this is the year
6) yes

Thank you !
 
Last edited:

HelenL

New Member
Joined
Nov 17, 2008
Messages
26
Thank you so much that brilliant. works a treat !
 

Forum statistics

Threads
1,089,619
Messages
5,409,376
Members
403,260
Latest member
ssauk

This Week's Hot Topics

  • help please
    SORRY NOT ANY GOOD AT EXCEL SO HELP WOULD BE MUCH APPRECIATED this formula is in a sheet called ignore...
  • two formulas needed
    Hello, I'll try my best to explain this: First formula needed in Sheet1 cell A2: If Sheet1 cell B2 = Sheet2 cell B2 then return a 1. If not then...
  • Dynamic Counts
    Good afternoon, we are tidying up some data & the data seems to be growing quicker than we are tidying it up! What we confirm (by reviewing it...
  • Help Excel formula eliminate duplicate values and keep only 2 identical rows.
    as picture below column A has a duplicate value. but the values are not the same as the rule. sometimes 4 rows, sometimes 10 rows or 7 or 9...
  • Macro Compile Error Sub or Function not defined
    Hello, I am trying to run macros from a validation list, all macros have been created and run perfectly on there own but I'm getting a compile...
  • Last row combined with Current Region VBA
    I'm generally happy finding the last row of data through something like Lastrow = Cells(Rows.Count, "D").End(xlUp) but I don't always receive data...
Top