Skip to content

Printing barcodes the lean and mean way from Excel using an old Zebra TLP 2824 Barcode printer. The task was mainly about being able to print part number labels from a spreadsheet containing a Bill of Materials, but only an old printer was provided. Some use of code from here and there finally made this work past the biggest obstacle of sending …

JSBattista/Zebra-TLP2824-Printing-from-Excel

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 

Repository files navigation

Zebra-TLP2824-Printing-from-Excel

This Project was aimed at printing barcodes from a Bill of Material using an old TLP2824. There were some challenges, but a use of the EPL language and straight out prining to the device was essential. The project used a DLL created in VS 2017 Community to run the code that sends EPL tot the printer. The DLL is accessed by the Excel Spreadsheet via VBA code, importing the DLL in the usual way. The most difficult part was the simplest. Using the test program from Zebra provided the clue. In order to treat the printer like a file and use the Windows CreateFile subroutine on it, the proper "name" of the printer had to be known. The printer was connected via USB and identified as "USB001". But that was not good enough, and so this was more than just sending "raw" to a COM port. The clue was provided by Developer-Demo_Windows.exe in D:\Program Files (x86)\Zebra Technologies\link_os_sdk\PC-.NET\v2.13.898\demos\Release. Notably, the "magic string" was LPTPORT = "\?\usb#vid_0a5f&pid_0016#21j113600300#{28d78fad-5a12-11d1-ae5b-0000f803a8c2}" And this was used in the variable LPTPORT in the EPL demo from https://support.zebra.com/cpws/docs/zpl/zpl_elp_vbnet.htm For a C++ program, the string needed to be different. This is the sort of thing to be wary of in the world of "raw printing fu". char printer[] = "\\.\usb#vid_0a5f&pid_0016#21j113600300#{28d78fad-5a12-11d1-ae5b-0000f803a8c2}";

Another thing to watch out for with using DLLs from VBA is which kind of platform, x86 versus x64, that your Excel installation is. Mixing and matching tends to have unreliable results. It tends to be more reliant on the version of Excel than the operating system, as a DLL compiled for x86 worked on an x64 system but I didn't check and see what version of Excel I was using.

About

Printing barcodes the lean and mean way from Excel using an old Zebra TLP 2824 Barcode printer. The task was mainly about being able to print part number labels from a spreadsheet containing a Bill of Materials, but only an old printer was provided. Some use of code from here and there finally made this work past the biggest obstacle of sending …

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published