• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 1263
  • Last Modified:

Text to Columns in Access

I preface this question by clarifying that I already know how to accomplish this task in Excel, Word, TextPad etc.  I want to know if/how this can be done directly in MS Access to avoid the whole export-parse-import process.  

The "Original POST" column contains data that is grouped using dashes (-).  Some of the cells have 1 dash between two values (GATE2-001), others have 2 dashes separating 3 values (51-AB-492), and still others have no dashes and just a single value (0010)

What I need to do is to split this single column into 3 columns, RIGHT JUSTIFIED, using the dash as a delimiter.  See example below.  Is this possible in Access?  If so, what is the syntax?  (the spacing of this sample isn't great, please view the attached file for a better look)
                                           
Original POST      Resulting POST      NewCol 1            NewCol 2
GATE-001                        GATE            001
GATE-002                        GATE            002
GATE-003                        GATE            003
GATE-004                        GATE            004
GATE-005                        GATE            005
51-AB-492            51            AB            492
51-AB-493            51            AB            493
51-AB-494            51            AB            494
51-AB-495            51            AB            495
51-AB-496            51            AB            496
51-AB-497            51            AB            497
00010                                    00010
00011                                    00011
00012                                    00012
00013                                    00013
00014                                    00014
00015                                    00015
00016                                    00016

Text-to-Columns-Example.xls
0
Uniqueinc
Asked:
Uniqueinc
  • 6
  • 2
1 Solution
 
rockiroadsCommented:
do u want this solution in sql or vba. Certainly easy in vba, can make a vba func is probably a littler easier to read

add this to a module and save it (ensure module name not the same as func name)

Public Function GetPart(ByVal sSource As String, ByVal iPos As Integer) As String

    Dim sWords() As String
   
    If InStr(1, sSource, "-") > 0 Then
        If InStrRev(sSource, "-") = InStr(1, sSource, "-") Then
            sSource = "-" & sSource
        End If
    Else
        sSource = "--" & sSource
    End If
    sWords = Split(sSource, "-")
   
    If iPos > UBound(sWords) + 1 Then
        GetPart = ""
    Else
        GetPart = sWords(iPos - 1)
    End If
End Function




Now in your query do this

select ([Original POST], GetPart([Original POST],1) AS [Resulting Post], GetPart[Original POST],2) AS NewCol1, GetPart([Original POST],3) AS NewCol3
from mytable


0
 
rockiroadsCommented:
To test this, create a test func
eg
Public Sub TestGetPart()
    Debug.Print "COLUMN 1", "COLUMN 2", "COLUMN 3"
    Debug.Print GetPart("51-AB-492", 1), GetPart("51-AB-492", 2), GetPart("51-AB-492", 3)
    Debug.Print GetPart("GATE-001 ", 1), GetPart("GATE-001 ", 2), GetPart("GATE-001", 3)
    Debug.Print GetPart("00012", 1), GetPart("00012", 2), GetPart("00012", 3)
End Sub


and run this (click anywhere in code and hit F5) then check results in immediate window. It looks like this

COLUMN 1      COLUMN 2      COLUMN 3
51            AB            492
              GATE          001
                            00012
0
 
UniqueincAuthor Commented:
I'd like to do it in an Access query, if possible.  

Along this line, I've copied your sample into a new Access query, and it gives me a syntax error (Missing operator) around the 'AS [Resulting Post]' section.  Any ideas?
0
Cloud Class® Course: Python 3 Fundamentals

This course will teach participants about installing and configuring Python, syntax, importing, statements, types, strings, booleans, files, lists, tuples, comprehensions, functions, and classes.

 
rockiroadsCommented:
Sorry about that. I had a rogue opening ( and one missing also

corrected sql

select [Original POST], GetPart([Original POST],1) AS [Resulting POST], GetPart([Original POST],2) AS NewCol1, GetPart([Original POST],3) AS NewCol3
from mytable


change mytable to your tablename obviously

0
 
rockiroadsCommented:
Original POST      Resulting POST      NewCol1      NewCol3
51-AB-492      51      AB      492
GATE-001            GATE      001
00012                  00012
0
 
rockiroadsCommented:
man, display is messed up.

With regards to a access query, it probably can be done but will be full of iif's probably, a little messy. Thats why I prefer a easier to read and maintain solution by using udf's.
0
 
UniqueincAuthor Commented:
I misunderstood before.  I realize now that you were saying to use the the query in conjunction with the VB code.  I was trying to use it independently.  

It only takes a couple of minutes to export the table to Excel, split the columns and re-import into Access.  I was hoping to speed things up by running a query directly in Access, but if that takes longer than my original plan, it's not worth it.  

I appreciate your time, and that you didn't make me feel like an idiot, as usually happens here:-)
0
 
rockiroadsCommented:
Sometimes takes a few posts before we gain an understanding. An expert here is not an expert if they don't have the patience and are not able to adjust their responses accordingly.

if this is a one off you could try a vba approach only by opening a recordset

eg just past in a module, this runs by itself

Public Sub SortMyTableOut()
   
    Dim rs As dao.Recordset
    Dim sWords() As String
    Dim sSource As String
   

    Debug.Print "Working"

'enter your tablename here
    Set rs = CurrentDb.OpenRecordset("tblpost")
    Do While rs.EOF = False
       
        rs.Edit
       
        sSource = Nz(rs("Original POST"), "")
       
        'Dump in immediate window - comment out to slightly speed it up more
        Debug.Print "Processing", sSource
       
        If InStr(1, sSource, "-") > 0 Then
            If InStrRev(sSource, "-") = InStr(1, sSource, "-") Then
                sSource = "-" & sSource
            End If
        Else
            sSource = "--" & sSource
        End If
        sWords = Split(sSource, "-")
       
        If 1 > UBound(sWords) + 1 Then
            rs("Resulting POST").Value = ""
        Else
            rs("Resulting POST").Value = sWords(0)
        End If
       
        If 2 > UBound(sWords) + 1 Then
            rs("NewCol1").Value = ""
        Else
            rs("NewCol1").Value = sWords(1)
        End If
       
        If 3 > UBound(sWords) + 1 Then
            rs("NewCol2").Value = ""
        Else
            rs("NewCol2").Value = sWords(2)
        End If
       
        rs.Update
       
        rs.MoveNext
    Loop
    rs.Close
    Set rs = Nothing
End Sub



0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Free Tool: Port Scanner

Check which ports are open to the outside world. Helps make sure that your firewall rules are working as intended.

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.

  • 6
  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now