Solved

Text to Columns in Access

Posted on 2009-04-06
9
1,231 Views
Last Modified: 2012-06-27
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
Comment
Question by:Uniqueinc
[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
  • 6
  • 2
9 Comments
 
LVL 65

Expert Comment

by:rockiroads
ID: 24080204
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
 
LVL 65

Expert Comment

by:rockiroads
ID: 24080246
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
 

Author Comment

by:Uniqueinc
ID: 24080505
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
Use Case: Protecting a Hybrid Cloud Infrastructure

Microsoft Azure is rapidly becoming the norm in dynamic IT environments. This document describes the challenges that organizations face when protecting data in a hybrid cloud IT environment and presents a use case to demonstrate how Acronis Backup protects all data.

 
LVL 65

Expert Comment

by:rockiroads
ID: 24080957
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
 
LVL 65

Expert Comment

by:rockiroads
ID: 24080965
Original POST      Resulting POST      NewCol1      NewCol3
51-AB-492      51      AB      492
GATE-001            GATE      001
00012                  00012
0
 
LVL 65

Expert Comment

by:rockiroads
ID: 24080978
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
 

Author Comment

by:Uniqueinc
ID: 24081323
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
 
LVL 65

Accepted Solution

by:
rockiroads earned 250 total points
ID: 24081505
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

Featured Post

Free Tool: IP Lookup

Get more info about an IP address or domain name, such as organization, abuse contacts and geolocation.

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

In Part II of this series, I will discuss how to identify all open instances of Excel and enumerate the workbooks, spreadsheets, and named ranges within each of those instances.
Containers like Docker and Rocket are getting more popular every day. In my conversations with customers, they consistently ask what containers are and how they can use them in their environment. If you’re as curious as most people, read on. . .
In Microsoft Access, learn different ways of passing a string value within a string argument. Also learn what a “Type Mis-match” error is about.
In Microsoft Access, when working with VBA, learn some techniques for writing readable and easily maintained code.

759 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