Solved

VBA Excel: How to save in text file format with double quotes

Posted on 1998-10-08
4
1,319 Views
Last Modified: 2009-12-16
I am trying to save a worksheet into a .txt file. All the
data is in the first column of the worksheet, compiled from
other worksheets:
1) Whenever I save this worksheet all the double quotes (")
are preceded by an additional double quote (""). The result
in the file looks like ("text=""blabla"""). It should look
like text="blabla". So I got one new double quote for all
quotes and two that enclose the whole string (unwanted as
well)
2) "Save as" .prn format works but is limited to
something like 239 characters. I have lines that are
longer!
3) General question (1 and 2 are more important).
Is there some kind of esape sequence
in Excel so that I can display a double quote in a cell
without the stupid workaround I'm using right now (Paste a
double quote in an unused cell and refer to it whereever
I need double quotes)
0
Comment
Question by:Lewis
  • 2
  • 2
4 Comments
 
LVL 2

Accepted Solution

by:
mkmccreary earned 100 total points
ID: 1438924
Here is a little VB function to write your data.  You may have to modify it for your particular situation:

Function WriteTextFile() As Long

Dim sCellData As String
Dim lCounter As Long
Dim iFileHandle As Integer

    iFileHandle = FreeFile
    Open "c:\temp\Cells.txt" For Output As iFileHandle
    lCounter = 1
    sCellData = Worksheets("Sheet1").Cells(lCounter, 1).Value
    While sCellData <> ""
        Print #iFileHandle, sCellData
        lCounter = lCounter + 1
        sCellData = Worksheets("Sheet1").Cells(lCounter, 1).Value
    Wend
   
    Close iFileHandle
   
    WriteTextFile = True
   
End Function


As For question 3, you can use Chr$(34) which is double quotes.  
Ex:
    Worksheets("Sheet1").Cells(4, 1).Value = "Value=" & Chr$(34) & "blabla" & Chr$(34)

0
 

Author Comment

by:Lewis
ID: 1438925
Hi,
the code for saving works great (I connected it with a button on the Excel worksheet).
Thanks. But I still need a solution for the problem with the double quotes.
I would like to concatenate cells from one worksheet and put double quotes around
it (cell1: Value, cell 2: abc123 should result in: Value="abc123"). I tried it with
=Sheet1!A1&"="&Chr$(34)&Sheet1!B1&Chr$(34)
but this doesn't work.
So what I would need is something like an escape character for double quotes like the
backslash in C where with \\ you produce a single \.
Maybe I should post this question not here in the VB section but in another one for
office products. If you cannot answer I will give you your (well earned) points and try it
there.

/Lewis
0
 
LVL 2

Expert Comment

by:mkmccreary
ID: 1438926
Lets try something.  Execute the code below in your workbook.


Function CombineCells() As Long

Dim sCellData As String
Dim sTotal As String
Dim lCounter As Long

    lCounter = 1
    sTotal = ""
    sCellData = Worksheets("Sheet1").Cells(lCounter, 1).Value
    While sCellData <> ""
        sTotal = sTotal & sCellData
        lCounter = lCounter + 1
        sCellData = Worksheets("Sheet1").Cells(lCounter, 1).Value
    Wend
   
    Worksheets("Sheet1").Cells(lCounter + 5, 1).Value = "Value = " & Chr$(34) & sTotal & Chr$(34)
    CombineCells = True
     
End Function


It is basically the same thing you had before, except it combines all the fields and then writes this combination to the cell five below the last cell.  See if it does what you are talking about.

Later,
Martin
0
 

Author Comment

by:Lewis
ID: 1438927
Hi Martin,
I found it myself. You just have to put &"""" into your formula bar.

Thanks for your prompt response,
Lewis.
0

Featured Post

Free Tool: SSL Checker

Scans your site and returns information about your SSL implementation and certificate. Helpful for debugging and validating your SSL configuration.

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

Have you ever wanted to restrict the users input in a textbox to numbers, and while doing that make sure that they can't 'cheat' by pasting in non-numeric text? Of course you can do that with code you write yourself but it's tedious and error-prone …
Article by: Martin
Here are a few simple, working, games that you can use as-is or as the basis for your own games. Tic-Tac-Toe This is one of the simplest of all games.   The game allows for a choice of who goes first and keeps track of the number of wins for…
Get people started with the utilization of class modules. Class modules can be a powerful tool in Microsoft Access. They allow you to create self-contained objects that encapsulate functionality. They can easily hide the complexity of a process from…
This lesson covers basic error handling code in Microsoft Excel using VBA. This is the first lesson in a 3-part series that uses code to loop through an Excel spreadsheet in VBA and then fix errors, taking advantage of error handling code. This l…

821 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