Jump to content

Welcome to the new Traders Laboratory! Please bear with us as we finish the migration over the next few days. If you find any issues, want to leave feedback, get in touch with us, or offer suggestions please post to the Support forum here.

  • Welcome Guests

    Welcome. You are currently viewing the forum as a guest which does not give you access to all the great features at Traders Laboratory such as interacting with members, access to all forums, downloading attachments, and eligibility to win free giveaways. Registration is fast, simple and absolutely free. Create a FREE Traders Laboratory account here.

Tams

Print (EasyLanguage)

Recommended Posts

This thread is about the PRINT keyword in EasyLanguage

 

 

Print

 

Sends one or more specified expressions to the PowerLanguage Editor Output Log or another output target, if specified.

Any combination of string, true/false, numerical series, or numerical expressions can be specified.

 

 

Usage

 

Print([OutputTarget],Expression1,Expression2,etc.)

 

Parameter inside the square brackets is optional

 

 

 

Parameters

 

OutputTarget - an optional parameter; specifies an output target other then the PowerLanguage Editor Output Log; the parameter must be followed by a comma.

 

There are two optional output targets:

 

Printer

 

Specifies the default printer as the output target.

 

File("PathFilename")

 

Where: PathFilename - a string expression specifying the path and filename

 

Specifies an ASCII file as the output target; if the specified file does not exist, the file will be created.

 

If OutputTarget is not specified, the output will be sent to the PowerLanguage Editor Output Log.

 

 

 

Expression - a string, true/false, numerical series, or numerical expression; any number of valid expressions, separated by commas, can be used

 

A string expression must be enclosed in quotation marks:

 

"String Expression"

 

 

A numerical expression can be formatted to specify the minimum number of characters, including the decimal point, and the number of decimal places, to be used for the output:

 

Expression:C: D

 

Where:

C - minimum number of characters

D - number of decimal places

 

The default output format for a numerical expression is two decimal places and a minimum of seven characters.

 

If the number of decimal places in the numerical expression is more than the specified number, the value will be will be rounded off to the specified number of decimal places.

 

If the number of characters in the output is less than the specified minimum, leading spaces will be added to bring the output to the specified minimum value.

 

 

 

Examples

 

Print(.1);

will print 0.10 in the PowerLanguage Editor Output Log, with three leading spaces inserted

 

Print(1.555555:6:3);

will print 1.556 in the PowerLanguage Editor Output Log, with one leading space inserted

 

Print(Printer,"Print Test");

will send the string expression "Print Test" to the default printer

 

Print(File("C: \test.txt"),CurrentDate,CurrentTime);

will save the output of CurrentDate and CurrentTime to the test.txt file in the root directory of the C: hard drive

 

 

.

Share this post


Link to post
Share on other sites

It is probably worth mentioning that Print can be very useful for debugging something that runs but does not run correctly or to check that things are consistent.

 

You can use print statements to output variables or to help monitor the path of the program through loops and conditional statements.

Share this post


Link to post
Share on other sites
inputs:

Length( 14 ) ;

 

if CurrentBar > Length then

Plot1( CMO( Length ), "CMO" ) ;

Plot2( 0, "Zero" ) ;

print( plot1 ) ;

 

In the CMI indicators nothing is printed in the output PLE window except 53.49

 

print( plot1 ) = what is this for ?

 

For debugging ?

 

In case of errors it will print them ?

Share this post


Link to post
Share on other sites

It is supposed to print out the value of "plot1" at the end of each bar.

You can use the output for debugging,

or if it is output to a text file, for record keeping.

 

 

variations you can try:

 

print( text(plot1) ) ;

 

print( NumToStr(plot1, 6) ) ;

 

print( BarNumber, plot1 ) ;

 

print( " Date=", date, " Time=", time, " CMI=", plot1 ) ;

Share this post


Link to post
Share on other sites
It is probably worth mentioning that Print can be very useful for debugging something that runs but does not run correctly or to check that things are consistent.

 

You can use print statements to output variables or to help monitor the path of the program through loops and conditional statements.

 

Everything is said, specially for perfect beginners.

Share this post


Link to post
Share on other sites

if you amend this code to the indicator in the previous post,

your file log will get an automatic filename in this format:

 

symbolname-YYYYMMDDhhmm

 

e.g.: ESZ9-200910221313

 

i.e. you can have this code in any indicators, in any chart, with any symbol... your log files will be given a different name automatically.

 

 

// modified section

 

var:

File.name("");

 

if currentbar = 1 then

File.name =

"c:\docs\"

+ getsymbolname

+"-"

+ numtostr(currentdate+19000000,0)

+ numtostr(currenttime,0)

+ ".txt";

 

 

 

// Scan Print (for use in scanner)
// version: beta 0.2
// Author: TAMS
// License: public use
// 
// this indicator is for demonstration purpose only
//
// Description:
// this indicator scans the last bar on the chart,
// if the close is higher than previous bar's high,
// it will make a printout to
// a) the Output log window,
// b) the printer, or
// c) a file.
//
// see this thread for discussion
// http://www.traderslaboratory.com/forums/f46/scan-print-6194.html
//

Input:
Send.to.Log(true),
Send.to.printer(false),
Send.to.file(false);

var:
File.name("c:\docs\scan_print.txt");

{========== end of variables ==========}

{---------- auto filename ----------}

if currentbar = 1 then
File.name = 
"c:\docs\" 
+ getsymbolname 
+"-"
+ numtostr(currentdate+19000000,0)
+ numtostr(currenttime,0)
+ ".txt";

{---------- end of auto filename ----------}


if time <> time[1] then
begin
if c > h[1] then
begin
	if Send.to.Log then
	print(NumToStr(date+19000000,0), " C>H[1] " + getsymbolname);

	if Send.to.printer then
	print(printer, NumToStr(date+19000000,0), " C>H[1] " + getsymbolname);

	if Send.to.file then
	Fileappend(file.name, NumToStr(date+19000000,0) + " C>H[1] " + getsymbolname + newline);
end;
end;

Share this post


Link to post
Share on other sites

Hello all, I am new here.

 

I have a few questions about print().

 

1) If I am trying to get strategy/indicator data out of tradestation en mass into csv files in order to analyze it with other programs (excel, SAS etc) is print() the most efficient way to do this? Or is there some better way I can get all of my charts to print data automatically?

 

2) Is there a way to get column names to show up? E.g. "Date" "Close" "Moving Average" etc.?

 

I have tried the following:

 

If Currentbar = 1 then

print(file("C:\User\filename.txt"),"Date",",","Close",",","MA")

else

print(file("C:\User\filename.txt"),ELDateToString(Date),",",c,",",MA);

 

It works well enough (although it does skip the first bar of data) but it seems there must be a better built-in way?

 

3) I'd like to create an indicator called "PrintData" whose inputs include the file name and data to be printed. But easylanguage doesn't appear to let you treat the file name as an input. So print(file(FileNameInput),...) returns the error "File name expected here".

Is there any way I can get around this?

 

Side note: I only need end of day data, not intra-day, so computation time isn't a major concern.

 

Thanks,

Investor

Share this post


Link to post
Share on other sites
Hello all, I am new here.

 

I have a few questions about print().

 

1) If I am trying to get strategy/indicator data out of tradestation en mass into csv files in order to analyze it with other programs (excel, SAS etc) is print() the most efficient way to do this? Or is there some better way I can get all of my charts to print data automatically?

 

Welcome to TL, Investor!

 

I have come across more efficient methods in older books (eg. Thomas Stridsman's 'Trading Systems that Work'), in which the data is exported wholesale from tradestation, but have never been able to get them to work. Currently, I do almost exactly what you're doing, as I too have only ever needed end of day equity data. Still, it's clunky, and wide open to human error . . .

 

Hopefully Tams or someone else might have some suggestions?

 

BlueHorseshoe

Share this post


Link to post
Share on other sites

Hi BlueHorseshoe,

 

Thanks for your response. I'm glad to see others have been using the same method, so I'm not completely off the mark at least. I would be grateful if Tams or someone else could offer a more efficient way.

Any thoughts from anyone?

 

Investor

Share this post


Link to post
Share on other sites

Right click on a blank area in a chart and select View Data Window. Then right click in the Data Window and select Save. Specify .CSV for the filename extension (not txt) and it will export all the values that are plotted and automatically include column headings.

 

When exporting from within code you should also use csv rather than txt for the filetype. And FileAppend (instead of print) because it accepts variable filenames.

 

Hello all, I am new here.

 

I have a few questions about print().

 

1) If I am trying to get strategy/indicator data out of tradestation en mass into csv files in order to analyze it with other programs (excel, SAS etc) is print() the most efficient way to do this? Or is there some better way I can get all of my charts to print data automatically?

 

2) Is there a way to get column names to show up? E.g. "Date" "Close" "Moving Average" etc.?

 

I have tried the following:

 

If Currentbar = 1 then

print(file("C:\User\filename.txt"),"Date",",","Close",",","MA")

else

print(file("C:\User\filename.txt"),ELDateToString(Date),",",c,",",MA);

 

It works well enough (although it does skip the first bar of data) but it seems there must be a better built-in way?

 

3) I'd like to create an indicator called "PrintData" whose inputs include the file name and data to be printed. But easylanguage doesn't appear to let you treat the file name as an input. So print(file(FileNameInput),...) returns the error "File name expected here".

Is there any way I can get around this?

 

Side note: I only need end of day data, not intra-day, so computation time isn't a major concern.

 

Thanks,

Investor

Share this post


Link to post
Share on other sites

Although TradeStation does not appear to support dynamic file names, we can write that file name as the first item on each line to produce a file that can be filtered externally. I use Textpad for bookmarking lines that contain search criteria, then cut/paste bookmarked lines into a new file. If saving as a CSV, you can use excel to filter the document on same.

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


  • Topics

  • Posts

    • QBTS D-Wave Quantum stock with a local breakout, good volume +235% at https://stockconsultant.com/?QBTS
    • PLAY Dave & Busters Entertainment stock, big bounce off the lower 24.48 double support area at https://stockconsultant.com/?PLAY
    • INO Inovio Pharmaceuticals stock, watch for a bottom breakout above 2.33 at https://stockconsultant.com/?INO
    • CADL Candel Therapeutics stock, watch for a range breakout, target 12 area, volume +82% at https://stockconsultant.com/?CADL
    • Date: 19th February 2025.   Is the DAX Overbought After Rising For 7 Weeks Straight?   The DAX rose by 20% in 2024, however, in 2025 so far the DAX has risen more than 15% in only 50 days. The DAX has risen for seven straight weeks, driven by rate cuts and strong earnings reports. Can the DAX maintain momentum or is the price overbought? DAX 40 - What’s Driving the Bullish Trend? Three factors are driving the price of the DAX higher. The first is the European Central Bank which has cut for 2 consecutive months and is likely to adjust a further 0.75% in 2025. The lower interest rates and expectations of further cuts are known to support the DAX due to higher consumer demand.     The second factor driving prices higher are the positive earnings data. SAP SE is the most influential stock and has risen by 18% so far this year. SAP’s latest quarterly earnings report saw the company beat revenue expectations by 2.60% and earnings by 1.40%. The second most influential stock for the DAX is Siemens AG which has risen almost 20% in 2025 so far. All of the seven most influential stocks have risen in value this year so far and only 17% of the whole DAX have declined this year so far. However, traders should note that not all companies within the DAX have made public their quarterly earnings reports. The third factor is the expectation that the Ukraine-Russia conflict will end or reach a ceasefire in the first half of the year. Traders should note that an end to the conflict is more crucial for European indices in comparison to Asian or US indices. This is due to the nature of Europe and European geopolitics. Is the German DAX Overbought? When analyzing the price movement the index is trading in the overbought zone on most oscillators and on most timeframes. However, price action and previous impulse waves indicate the price will not be overbought unless the price increases above 23,250EUR. However, the intrinsic value of the DAX will also depend on US tariffs. If Germany is able to avoid harsh US tariffs, German stocks may continue to increase higher as sentiment improves. However, harsh tariffs are likely to apply downward pressure on the index and increase the likelihood of being overbought in the short-to-medium term. If the price indeed declines, traders may first target the support level at $22,437.58, which will likely fall in line with the 75-period Moving Average. The main bullish breakout point is at the 22,724.30 mark. Tariffs on Foreign Cars A key risk for the DAX as mentioned above is US tariffs, particularly on cars. The DAX index includes Mercedes-Benz, Porsche AG, BMW, and Volkswagen. Total new cars sales in the US from these 4 companies make up almost 10% of the overall sales.     Donald Trump remained defiant despite warnings that his proposed trade war could disrupt the US economy, stating that his administration might impose tariffs of approximately 25% on foreign cars within weeks. He also announced that semiconductor chips and pharmaceuticals would soon face higher tariffs, speaking at a news conference on Tuesday. Key Takeaway Points: The DAX has surged over 15% in 2025, driven by ECB rate cuts, strong earnings, and optimism over the Ukraine conflict. SAP SE and Siemens AG are the top-performing stocks and 83% of the DAX has witnessed gains. However, some earnings reports are still pending. Despite trading in overbought territory, the index may continue rising unless it faces harsh US tariffs. Potential US tariffs on foreign cars pose a key risk, impacting major DAX-listed car makers. This includes Mercedes-Benz, Porsche AG, BMW, and Volkswagen. Always trade with strict risk management. Your capital is the single most important aspect of your trading business.   Please note that times displayed based on local time zone and are from time of writing this report.   Click HERE to access the full HFM Economic calendar.   Want to learn to trade and analyse the markets? Join our webinars and get analysis and trading ideas combined with better understanding of how markets work. Click HERE to register for FREE!   Click HERE to READ more Market news.   Michalis Efthymiou HFMarkets   Disclaimer: This material is provided as a general marketing communication for information purposes only and does not constitute an independent investment research. Nothing in this communication contains, or should be considered as containing, an investment advice or an investment recommendation or a solicitation for the purpose of buying or selling of any financial instrument. All information provided is gathered from reputable sources and any information containing an indication of past performance is not a guarantee or reliable indicator of future performance. Users acknowledge that any investment in Leveraged Products is characterized by a certain degree of uncertainty and that any investment of this nature involves a high level of risk for which the users are solely responsible and liable. We assume no liability for any loss arising from any investment made based on the information provided in this communication. This communication must not be reproduced or further distributed without our prior written permission.
×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.