Jump to content
Sign in to follow this  
Attckdog

Excel Format Cell as Text

Recommended Posts

Attckdog

I've got a tab delimited text file that needs column headers added.

As you might be able to see it's for an Amazon Order confirmation File.

With my current experience with autoit I figured the best way to make this happen would be to use excel.

Only problem is that excel is being a punk and changing my numbers to short hand.

The numbers that are being changed are FedEx Tracking numbers like: 064089467117955

End up like this: 6.40895E+13

So i was looking for a better way to do this or a way to prevent my cells from being changed.

Here's my Code:

FileCopy("Y:\New Folder\HOLDFILEEXPORT.txt", "C:\Amazon\HOLDFILEEXPORT.txt", 1)
FileCopy("C:\Amazon\HOLDFILEEXPORT.txt", "C:\Amazon\HOLDFILEEXPORT.xls", 1)

$oExcel = _ExcelBookAttach("C:\Amazon\HOLDFILEEXPORT.xls")
_ExcelRowInsert($oExcel, 1, 1)
Sleep(10)
_ExcelWriteCell($oExcel, "order-id", 1, 1)
Sleep(10)
_ExcelWriteCell($oExcel, "order-item-id", 1, 2)
Sleep(10)
_ExcelWriteCell($oExcel, "quantity", 1, 3)
Sleep(10)
_ExcelWriteCell($oExcel, "ship-date", 1, 4)
Sleep(10)
_ExcelWriteCell($oExcel, "carrier-code", 1, 5)
Sleep(10)
_ExcelWriteCell($oExcel, "carrier-name", 1, 6)
Sleep(10)
_ExcelWriteCell($oExcel, "tracking-number", 1, 7)
Sleep(10)
_ExcelWriteCell($oExcel, "ship-method", 1, 8)
Sleep(10)
_ExcelBookClose($oExcel)

A true renaissance man

Share this post


Link to post
Share on other sites
water

There is an extended Excel UDF available called with many useful functions extending the functionality of the UDF that comes with AutoIt.

Function _ExcelNumberFormat should do what you want.

Example: _ExcelNumberFormat($l_ExcelReport,"@","A1:A65536") formats the specified range as text.


My UDFs and Tutorials:

Spoiler

UDFs:
Active Directory (NEW 2017-04-18 - Version 1.4.8.0) - Download - General Help & Support - Example Scripts - Wiki
OutlookEX (NEW 2017-02-27 - Version 1.3.1.0) - Download - General Help & Support - Example Scripts - Wiki
ExcelChart (2015-04-01 - Version 0.4.0.0) - Download - General Help & Support - Example Scripts
Excel - Example Scripts - Wiki
Word - Wiki
PowerPoint (2015-06-06 - Version 0.0.5.0) - Download - General Help & Support

Tutorials:
ADO - Wiki

 

Share this post


Link to post
Share on other sites
kylomas

Attckdog,

Find a better behaved copy of Excel...if it was working before the headers then the cell format changed.

kylomas

Edit: whoops, too slow, water beat me in...good luck!!

Edited by kylomas

Forum Rules         Procedure for posting code

"I like pigs.  Dogs look up to us.  Cats look down on us.  Pigs treat us as equals."

- Sir Winston Churchill

Share this post


Link to post
Share on other sites
Zedna

There is an extended Excel UDF available called with many useful functions extending the functionality of the UDF that comes with AutoIt.

Function _ExcelNumberFormat should do what you want.

Example: _ExcelNumberFormat($l_ExcelReport,"@","A1:A65536") formats the specified range as text.

Thanks for info. I can use it in the future too.

Do you know how to reformat whole column? How to specify range for whole column?

_ExcelNumberFormat($l_ExcelReport,"@","A1:A65536") ; formats the specified range as text.

Share this post


Link to post
Share on other sites
water

I'm not at my windows PC at the moment but IIRC you specify a column (e.g. column A ) as "A:A"

Edited by water

My UDFs and Tutorials:

Spoiler

UDFs:
Active Directory (NEW 2017-04-18 - Version 1.4.8.0) - Download - General Help & Support - Example Scripts - Wiki
OutlookEX (NEW 2017-02-27 - Version 1.3.1.0) - Download - General Help & Support - Example Scripts - Wiki
ExcelChart (2015-04-01 - Version 0.4.0.0) - Download - General Help & Support - Example Scripts
Excel - Example Scripts - Wiki
Word - Wiki
PowerPoint (2015-06-06 - Version 0.0.5.0) - Download - General Help & Support

Tutorials:
ADO - Wiki

 

Share this post


Link to post
Share on other sites
jchd

@Attckdog

I don't get why you insist of going thru Excel (causing issues) just for the purpose of inserting a header line in a .CSV

First, AFAICT Amazon delivers CSV files with headers. At least it was the case until recently where we stopped selling there.

Now, if ever the CSV files you get miss the header line and all you want in the first place is have it, why not just prepending it to the CSV? That's 5 lines of code.

Finally, I guess you're going to process your CSV file somehow, presumably with AutoIt. If that's the case you don't even need the first step.

In any case, be warned that all platforms (Amazon, Paypal, eBay, YouNameIt) have great fun changing their CSV columns, headers and even semantics from time to time without any prior nor post notice. That means that you'll have to sanitize this kind of input with extreme caution at the risk of processing wrongly interpreted data, up to random garbage.

OMG I was talking about CSVs, but Amazon delivers TSV (tab separated values). That makes no difference anyway.


This wonderful site allows debugging and testing regular expressions (many flavors available). An absolute must have in your bookmarks.
Another excellent RegExp tutorial. Don't forget downloading your copy of up-to-date pcretest.exe and pcregrep.exe here
RegExp tutorial: enough to get started
PCRE v8.33 regexp documentation latest available release and currently implemented in AutoIt beta.

SQLitespeed is another feature-rich premier SQLite manager (includes import/export). Well worth a try.
SQLite Expert (freeware Personal Edition or payware Pro version) is a very useful SQLite database manager.
An excellent eBook covering almost every aspect of SQLite3: a must-read for anyone doing serious work.
SQL tutorial (covers "generic" SQL, but most of it applies to SQLite as well)
A work-in-progress SQLite3 tutorial. Don't miss other LxyzTHW pages!
SQLite official website with full documentation (may be newer than the SQLite library that comes standard with AutoIt)

Share this post


Link to post
Share on other sites
Attckdog

@Attckdog

I don't get why you insist of going thru Excel (causing issues) just for the purpose of inserting a header line in a .CSV

OMG I was talking about CSVs, but Amazon delivers TSV (tab separated values). That makes no difference anyway.

Yeah I just use the excel method because most of my experience with Autoit is in processing information from excel files.

So my first thing to attempt was to use what I already knew how to do.

What all would i use to edit the file in autoit without using excel stuff? I haven't done anything like that without excel files.

I'm not worried about the headers changing in Amazon because in the event of something not working properly it will just fail.

I'm only using these files to confirm with the tracking numbers. I will have to baby sit the script any how so no worries.


A true renaissance man

Share this post


Link to post
Share on other sites
Attckdog

Thanks water for the help. I eventually got the excel method to work.

After looking at the finished product I decided to scrap it. jchd was quite right. I was taking the hardest route.

After reading up on processing text files I found it was actually quite easy.

Here is the code I whipped up to use in place of what I was using.

Anyone is welcome to use it.

#include<File.au3>
Local $ReadFileArray
_FileReadToArray(@ScriptDir & "\Test.txt", $ReadFileArray)
FileWrite(@ScriptDir & "\TestResult!.txt", "order-id order-item-id quantity ship-date carrier-code carrier-name tracking-number ship-method" & @CRLF)
$file = FileOpen(@ScriptDir & "\TestResult!.txt", 1)
_FileWriteFromArray($file, $ReadFileArray, 1)
FileClose($file)

This will Make the confirmation file i needed with the desired column heads.

/Thead


A true renaissance man

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  

  • Similar Content

    • Gowrisankar
      By Gowrisankar
      Dear members of the forum,
      I need to open excel files that may or may not need a password and finally move the files that needs password to manual queue.
      Is there a fastest way to do this?
       
      PS: I have a huge respect for the rules of this forum. I am not asking assistance to override any security measure. I just need to segregate the files that needs passwords.
    • MrCheese
      By MrCheese
      Hi guys,
      without including everything (unless you want it)
      I am copying data from a table in chrome and wanting to paste it into excel.
      Copying in Chrome works.
      I can paste it into the field i want by emulating goto -> ctrl V:
      WinActivate($dataload) WinWaitActive($dataload) Sleep(500) $oWorkbook1.Sheets("ItemReturn").Activate Sleep(500) $msg = "Measuring Sheet" conwrite() ttips2() Local Const $xlUp = -4162 With $oWorkbook1.ActiveSheet ; process active sheet $oRangeLast = .UsedRange.SpecialCells($xlCellTypeLastCell) ; get a Range that contains the last used cells $iRowCount = .Range(.Cells(1, 1), .Cells($oRangeLast.Row, "B")).Rows.Count ; get the the row count for the range starting in row/column 1 and ending at the last used row/column $iLastCell = .Cells($iRowCount + 1, "B").End($xlUp).Row ; start in the row following the last used row and move up to the first used cell in column "B" and grab this row number EndWith $NewStartCell = $iLastCell + 2 $msg = "moving to location" conwrite() ttips2() Sleep(250) Send("^g") WinWait("Go To") Sleep(100) Send("B" & $NewStartCell) Sleep(100) Send("{ENTER}") Sleep(500) Send("^v")  
      But, I want to use _excel_rangecopypaste, pasting from the clipboard
      _Excel_RangeCopyPaste($oWorkbook1.ActiveSheet, default, "B" & $NewStartCell,default,$xlPasteValuesAndNumberFormats) If @error Then Exit MsgBox($MB_SYSTEMMODAL, "Excel UDF: _Excel_RangeCopy Example 2", "Error pasting cells." & @CRLF & "@error = " & @error & ", @extended = " & @extended) however, this gives me error 4 , extended@:  -2147352567
      How can i fix this or find out how to debug this error?
       
      Thanks
    • Simpel
      By Simpel
      Hi.
      I try to figure out who is using a excel workbook which I can only open "read only". I use this code:
      #include <Array.au3> #include <Excel.au3> Local $sFile = ; excel file with path on a network drive Local $oExcel = _Excel_Open(True, True) Local $oTabelle = _Excel_BookOpen($oExcel, $sFile) Local $aUsers If IsObj($oTabelle) Then $aUsers = $oTabelle.UserStatus _ArrayDisplay($aUsers) EndIf If I am the one allowed to write to the excel file (I'm the first one who opened it) then I will get an array with myself:

      If my collegue opened the excel file first and I run the code I get the following error message:
      "H:\_Conrad lokal\Downloads\AutoIt3\_COX\Tests\test.au3" (9) : ==> The requested action with this object has failed.: $aUsers = $oTabelle.UserStatus $aUsers = $oTabelle^ ERROR The excel file is on a network drive. Is that's the problem?
      Regards, Conrad
    • robertocm
      By robertocm
      change linked image paths in excel 2007 Open XML Files with AutoIt and 7-zip:
      #include <File.au3> ;Change this Local $sFind = "C:\Users\MyUserName\Documents\MyImageFolder\My%20Image1.png" Local $sReplace = "C:\Users\ANOTHERUSERNAME\Documents\AnotherImageFolder\My%20Image1.png" Local Const $sMessage = "Directory to change excel image paths" Local $sFileSelectFolder = FileSelectFolder($sMessage, "") Local $sTempDir = @ScriptDir & "\testdir" ;Required 7-zip Local $PathZipProgram = @ProgramFilesDir & "\7-Zip\" If Not(FileExists($PathZipProgram & "\7z.exe")) Then MsgBox(16, "", "7z.exe not found in path " & $PathZipProgram) Exit EndIf ;look for excel files in selected directory and all subdirectories Local $SFileList = _FileListToArrayRec($sFileSelectFolder, "*.xls.;*.xlsm", $FLTAR_FILES, $FLTAR_RECUR, $FLTAR_NOSORT, $FLTAR_FULLPATH) If Not @error Then For $i = 1 To $SFileList[0] DirRemove($sTempDir, 1) ;use x command to keep the folder stucture, -aoa Overwrite All existing files without prompt, use -r to unzip the subfolders from the zip file RunWait('"' & $PathZipProgram & '7z.exe" x -aoa -r "' & $SFileList[$i] & '" -o"' & $sTempDir & '" -y', $PathZipProgram, @SW_HIDE) __ReplaceImagePaths($sTempDir, $sFind, $sReplace) RunWait('"' & $PathZipProgram & '7z.exe" a -r "' & $SFileList[$i] & '" "' & $sTempDir & '\*" -tzip -y', $PathZipProgram, @SW_HIDE) Next Else MsgBox(16, "Error", "No files were found in the folder specified.") EndIf DirRemove($sTempDir, 1) Func __ReplaceImagePaths($sTempDir, $sFind, $sReplace) ;List all files with .xml.rels extension in the directory \xl\drawings\_rels Local $aFileList = _FileListToArray($sTempDir & "\xl\drawings\_rels", "*.xml.rels", 1, True) If @error = 1 Then ;MsgBox (0, "", "Path was invalid") SplashTextOn("Title", "Path was invalid", -1, -1, -1, -1, 1, "", 24) Sleep(2000) SplashOff() Exit EndIf If @error = 4 Then ;MsgBox (0, "No files", "No files were found") SplashTextOn("Title", "No files were found", -1, -1, -1, -1, 1, "", 24) Sleep(2000) SplashOff() Exit EndIf Local $iRetval ;Loop through the array For $i = 1 To $aFileList[0] $iRetval = _ReplaceStringInFile($aFileList[$i], $sFind, $sReplace) Next EndFunc  
      Some references:
      https://stackoverflow.com/questions/37145369/change-path-to-picture-links-in-excel http://www.jkp-ads.com/Articles/Excel2007FileFormat.asp EDITED:
      Note: it seems that if User Account Control (UAC) is enabled then 7zip is unable to overwrite the destination file (using the same name).
      In this case, a possible solution would be to rename the original excel file before (see _PathSplit in help file).
      In my case i prefer just to disable UAC
    • SOF-TECH
      By SOF-TECH
      Dear all,
      Can someone show  me how to en hance the below function to write in CSV  into column  and rows the input values ? 
      I am getting this result: 

      I would like the result to be as this 

      From A1:C1 is for headers
      From A2:C2 is for input Data
      Global Const $GUI_EVENT_CLOSE = -3 $sDataFilePath = @ScriptDir & "\Records.csv" #region ### START Koda GUI section ### Form= $Form1 = GUICreate("Demo1: New Record", 580, 115) $Input1 = GUICtrlCreateInput("", 10, 30, 270, 21) $Input2 = GUICtrlCreateInput("", 300, 30, 270, 21) $Input3 = GUICtrlCreateInput("", 10, 80, 270, 21) $Label1 = GUICtrlCreateLabel("Name:", 10, 10, 35, 17) $Label2 = GUICtrlCreateLabel("ID:", 300, 10, 18, 17) $Label3 = GUICtrlCreateLabel("Phone No:", 10, 60, 55, 17) $Button1 = GUICtrlCreateButton("Save to CSV", 450, 70, 120, 30) GUISetState(@SW_SHOW) #endregion ### END Koda GUI section ### While 1 $nMsg = GUIGetMsg() Switch $nMsg Case $GUI_EVENT_CLOSE Exit Case $Button1 _ExportData() MsgBox(64, @ScriptName, "Record Saved.") EndSwitch WEnd Func _ExportData() If Not FileExists($sDataFilePath) Then FileWriteLine($sDataFilePath, "Name;ID;Phone No.;") EndIf For $i = $Input1 To $Input3 FileWrite($sDataFilePath, GUICtrlRead($i) & ";") Next FileWriteLine($sDataFilePath, "") EndFunc ;==>_ExportData May be Excel UDF has be to be added but I can manage that my self  
      Thank you in advance
×

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.