Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations IamaSherpa on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

Break out a part number into seperate fields 3

Status
Not open for further replies.

03Explorer

Technical User
Sep 13, 2005
304
US
I have part numbers like this: 5-6-2-3-1-1

I want each numeric value to be populating a column of its own

Code:
first     second     third     fourth    fifth     sixth
=====     ======     =====     ======    =====     =====
5         6          2         3         1         1

However, the catch is there could be double or triple digits between dashes
5-67-2-3-1-1
5-6-2-231-1-2
Code:
first     second     third     fourth    fifth     sixth
=====     ======     =====     ======    =====     =====
5         67          2         3         1         1
5         6           2         231       1         1


What is the best query method to break these out of the one string value?
 
Hi,

This doesn’t look like a query problem.

I’d import into Excel and use the Data > Text to columns... feature, DELIMIT on a DASH.

Skip,

[glasses]Just traded in my OLD subtlety...
for a NUance![tongue]
 
=\ I need the query to take values and populate another table that has a field per numeric value so when we report on the categories they are populated into foreign key fields. No Excel in this equation.
 
Are there ALWAYS 6 numbers?

Skip,

[glasses]Just traded in my OLD subtlety...
for a NUance![tongue]
 
Code:
SELECT 
  mid([Part Number],1,instr([Part Number],'-')-1)
, MID([Part Number],instr([Part Number],'-')+1,instr(instr([Part Number],'-')+1,[Part Number],'-')-instr([Part Number],'-')-1)
, MID([Part Number],
instr(instr([Part Number],'-')+1,[Part Number],'-')+1,
instr(instr(instr([Part Number],'-')+1,[Part Number],'-')+1,[Part Number],'-')-
instr(instr([Part Number],'-')+1,[Part Number],'-')-1)
, MID([Part Number],
instr(instr(instr([Part Number],'-')+1,[Part Number],'-')+1,[Part Number],'-')+1,
instr(instr(instr(instr([Part Number],'-')+1,[Part Number],'-')+1,[Part Number],'-')+1,[Part Number],'-')-
instr(instr(instr([Part Number],'-')+1,[Part Number],'-')+1,[Part Number],'-')-1)
, MID([Part Number],
instr(instr(instr(instr([Part Number],'-')+1,[Part Number],'-')+1,[Part Number],'-')+1,[Part Number],'-')+1,
instr(instr(instr(instr(instr([Part Number],'-')+1,[Part Number],'-')+1,[Part Number],'-')+1,[Part Number],'-')+1,[Part Number],'-')-
instr(instr(instr(instr([Part Number],'-')+1,[Part Number],'-')+1,[Part Number],'-')+1,[Part Number],'-')-1)
, MID([Part Number],
instr(instr(instr(instr(instr([Part Number],'-')+1,[Part Number],'-')+1,[Part Number],'-')+1,[Part Number],'-')+1,[Part Number],'-')+1,
999)

FROM [Your Table]

Skip,

[glasses]Just traded in my OLD subtlety...
for a NUance![tongue]
 
I would create a small user-defined function that can be used to return any section of text like this with any delimiter. You could call this like:

ParseText([Part Number],4,"-")
The "4" returns the 4th section.

Code:
Public Function ParseText(pstrText As String, intElement As Integer, _
        pstrDelimiter As String) As Variant
    Dim arText() As String
   On Error GoTo ParseText_Error

    arText() = Split(pstrText, pstrDelimiter)
    ParseText = arText(intElement - 1)
    
ExitParseText:
   On Error GoTo 0
   Exit Function

ParseText_Error:
    Select Case Err
        Case 9 'subscript out of range
            'don't do anything
        Case Else
            MsgBox "Error " & Err.Number & " (" & _
                Err.Description & ") in procedure ParseText of Module basParseText"
    End Select
    Resume ExitParseText
End Function

Duane
Minnesota
Hook'D on Access
MS Access MVP 2001-2016
 
Duane, I appreciate your concept and code. Skip, I believe your code is in raw great, but I lean towards the simple concept of having a function for the Rinse-and-Repeat concept of reusing code... Keeping it simple.

Thank you both for your time and efforts in answering my question!

Rob
Minneapolis also(Duane)
 
I’d go with Duane’s function, too!

Skip,

[glasses]Just traded in my OLD subtlety...
for a NUance![tongue]
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top