Carriage Return Not Needed

mdrollins83

New Member
Joined
Nov 19, 2017
Messages
4
I am attempting to write to a txt file in excel from two separate ranges in 2 different sheets. Below is the code that works, but it leaves a carriage return at the end of the txt file that I cannot have when importing into our software. Could anyone be able to help a VBA beginner out with this?

Code:
Sub WriteToTextFile()
  Dim fs As New FileSystemObject
  Dim rng1 As Range
  Dim ws As Worksheet
  Set ws = Sheets("1099 Import Header")
  Set txtfile = fs.CreateTextFile(ThisWorkbook.Path & "\1099 Import.txt")
  Set rng1 = ws.Range("List_1099H")
  For Each r In rng1.Cells
      For Each cel In r
         txtfile.Write cel.Value
      Next
      txtfile.Write vbNewLine
  Next
  Dim rng2 As Range
  Dim wr As Worksheet
  Set wr = Sheets("1099 Import Detail")
  Set rng2 = wr.Range("List_1099D")
  For Each r In rng2.Cells
      For Each cel In r
         txtfile.Write cel.Value
      Next
      txtfile.Write vbNewLine
  Next
End Sub
 

Excel Facts

Square and cube roots
The =SQRT(25) is a square root. For a cube root, use =125^(1/3). For a fourth root, use =625^(1/4).
You can try this modification to the code.
Code:
For Each r In rng1.Cells
      For Each cel In r
         txtfile.Write cel.Value
      Next
     [COLOR=#FF0000] If Not cel Is Nothing Then[/COLOR]
          txtfile.Write vbNewLine
      [COLOR=#FF0000]End If[/COLOR]
Next
 
Upvote 0
Welcome to the forum!

An If() can skip adding the extra newline. e.g.
Code:
If r <> rng2.Cells(rng2.Rows.Count, rng2.Columns.Count) Then _
        txtfile.Write vbNewLine
  Next
End Sub

Alternavely, if your ranges are in a column, transpose is needed.
Code:
Sub WriteToTextFile()
  Dim fs As New FileSystemObject, txtfile As Object
  Dim a, b, r As Range, fn$
  
  fn = ThisWorkbook.Path & "\1099 Import.txt"
  Set txtfile = fs.CreateTextFile(fn)
  Set r = Sheets("1099 Import Header").Range("List_1099H")
  a = Application.Transpose(r.Value)
  Set r = Sheets("1099 Import Detail").Range("List_1099D")
  b = Application.Transpose(r.Value)
  txtfile.Write Join(a, vbCrLf) & Join(b, vbCrLf)
  txtfile.Close
  Shell "cmd /c " & """" & fn & """", vbNormalFocus
End Sub
 
Last edited:
Upvote 0
Kenneth,

I tried your alternate code since it seems to run much faster, but when the two ranges are combined, it puts the last line of "a" and the first line of "b" on the same line.
 
Upvote 0
You can concatenate a vbCrLF between the 2 Join()'s to fix that. There are other methods to join 2 arrays rather than just concatenation. The best method depends on how much data you have. Transpose would not be appropriate had the ranges been 2 dimensional for example.
 
Upvote 0

Forum statistics

Threads
1,225,749
Messages
6,186,802
Members
453,373
Latest member
Ereha

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top