OPEN-SOURCE SCRIPT

EPS & Sales

Mis à jour
Hi everyone,

I just adapted a little utility script to visualise EPS % increase (quarters vs Year -1) and sales.

I used the code from ARUN_SAXENA and modified it to fix what I saw as issues.
(Using base 3M instead of 1M +
request.earnings(syminfo.tickerid, earnings.actual, ignore_invalid_symbol=true)
instead of
request.financial(syminfo.tickerid, "EARNINGS_PER_SHARE", "FQ")

Data will differ from MarketSmith because they use sometimes actual EPS sometimes standard, but think we can at least trust what we see in term of %

The tool is far from being perfect !

Notes de version
Just modified a condition that was making the script bug on given charts
Notes de version
MarketSmith tag added
Notes de version
Modified:
- Displays NaN when both EPS used for calculation are negative
- Displays + when increase is positive :)
- Modified calculation system, use the closer EPS to 0 when both reported and standard EPS are negative
We are now very close to the calculation method of MarketSmith.
Sometimes number differs but results are often close when differents.
To be honest I always confirm with shared graph on Twitter.
Notes de version
Now displays '#' in front of EPS growth % to indicate if an EPS for calculation is negative
Notes de version
Modified some comments to help to understand what I did.
if you have any constructive suggestions, please let me know in the comments
Notes de version
- You can now change colors to suit your theme
Notes de version
- Removed indicators that were polluting the visual overview
Notes de version
- Adjusted Original Colors
Notes de version
- The Script is now directly added to the chart when added
- Removed the grid transparency
- Added the possibility to choose the position of the table
Notes de version
- Added the possibility to show the gross margin
- Tried to display Yearly EPS but highly inaccurate results convinced me to only keep the code under comments in case someone one day is able to calculate manually ?
- I'm still not satisfied with the code.
Ex:
- CELH one result is missing
-AEHR, this shoudn't happen but in Da, We, Mo, results differs. The problem is that we need to search previous earning with time and sometimes it defers from one stock to another.
I would love to find a way to get previous earning without using the time.
Notes de version
- I have removed the colour from the table frame as it pollutes the price graph
Notes de version
- Modified the code because the case where actual EPS was negative and reported EPS was positive was not taken into account.
(Now the '#' is diplayed correctly)
- Added the possibility to display ROE
- Added the possibility to show EPS used for calculation
Notes de version
- Now return NaN when last EPS is negative and EPS of the previous year is positive
Notes de version
- Now possible to plot EPS curve on the graph with another scale on the left.
Please tell me if you don't like this update, because it adds a left scale whether this new option is checked or not
Notes de version
- I finally corrected the time base period and replace the "3M" by the function barssince. This corrected the bug on AEHR.
I complained about if few updates ago :)
Notes de version
- Found that plotting EPS line on another scale was not very usefull
So I decided to replace them by Arrow on the chart showing EPS date and EPS % variation as you can see on MarketSmith graph
I have no solution to plot them at the bottom of the graph, if you know how, don't hesitate to tell me in comment
(I can't reply to personal messages for now)
Notes de version
- Corrected the case in which EPS display is negative to avoid +-50%
Notes de version
- Now the color of positive or negative variations also affects the color of the text under the arrows
- You can select arrow colors
- You can select the 'EPS' text color
Notes de version
- You can now adjust the size of the table.
Notes de version
- Corrected the case where arrow displayed the wrong balue between EPS reported or standard
Notes de version
- Modified the case in which when both reported and standard EPS are negative, but the closer to 0 is > than -0.01, is not taken into account.
(Corrected the #+999% in APA which was #+712%)
Notes de version
- Added comparison regarding sales too
- Renamed all the variables in the code that were confusing
(+ some comments here and there to facilitate understanding)
- Integrated the calculation of QoQ EPS without changing the general appearance of the script
(This way I hope I won't be HARASSED anymore :p)
- Added the viewing of 3 additional quarters
And finally...
- I really hope that, like me, you'll love the new look ! (If not you can still save it to your taste)
Notes de version
(forgot to remove drawings on the chart...!)
Notes de version
- Corrected the display of QoQ Eps when equals to YoY (could have and unforced # in front of result)
Notes de version

- Finally managed to display the quarters in MMM-yy format:-)
Notes de version

- And corrected size of the text of the date that I forgot !
Notes de version

- Arranged the settings to allow an easier and more intuitive customization of the interface
Notes de version

Added :
- Now possible to see Sales on the graph under EPS information
- Changed the QoQ visual
- Added Sales QoQ
- Reorganised Input
- Now possible to change text Color on the graph independently
Notes de version

- Reduced the number of label to allow more historical data on the graph (regarding arrow part)
Notes de version
- Replaced 'NaN%' by 'N/A' and change color from red to black.
Notes de version
- Added the correct display of N/A vs N/A instead of NaN vs NaN on the table and on the arrows
- Changed color of the case where variation% = 0% in black color. (Both EPS & Sales)
- Corrected the display of +/-∞% by N/A.
Notes de version
- Now the script correctly displays EPS and % when the EPS value is the same twice in a row.
- Corrected the synchronization between the EPS and Sales rows in the table
LYTS and WING were not correct, now they are.
Notes de version
Arrow part:
- Modified NaN% value to N/A
- Modifier N/A color
- Corrected the 0% color

Table part:
- Changed GROSS MARGIN into GM
- Corrected the case where eps1 was negative and eps4 was 0 -∞% -> N/A
- NaN vs NaN -> N/A vs N/A on QQQ
- Recorrected the 0% color
(I think TV displayed me an old previous version of the script so I had to re-write the two last points)
Notes de version
- Now +0% in blue is turned to 0% in black :3
Notes de version
- On the EPS day, TradingView provides the same sales number than the previous one instead of seeking for the new one. This cause a wrong data display on the last line and it can bring confusion.
I decided to identifiy this time and replace the sales and variation number by N/A. I will remove this if TradingView correct this bug.
Notes de version
- Same change than above but for the text under arrows on graph.
Notes de version
- In the case of a sales display changed to N/A on the EPS day, the script now displays the sales value as soon as it is available. Here in the post-market of the earning day.
Notes de version
- Added the case where Sales are the same the day after the earning event
Notes de version
- Correction of a bug with the last update
Notes de version
- Corrected -10000% bug
- Now displays Sales in MIL or BIL
Notes de version
- Corrected the display of x,x Bil$ to xxxx,x Mil like MarketSmith
- Corrected the case where sales are the same number at day+1 after eanring event
Notes de version
- Added a black Frame arround the table
Notes de version
- Changed the size of the column to have the same ratio than MarketSmith's table
- Changed the Graph for better presentation
Notes de version
- Adjusted Colors
- Input have been reorganised and simplified
Notes de version
- Arrow size is now adjustable
- We can now display the %variation anyway even if the actual/reported EPS is negative
- Limitation added to -999%
- We can now display surprises on the table
- Input reorganised
Notes de version
- Little mistake on inputs, my bad! Corrected
Notes de version
- Corrected the display that was broken when "Surprise" and "Less Quarters" were checked.
- Changed to Presentation Graph
Notes de version
-Now possible to display the Daily Table of EPS & Sales.
(I did it because I was asked many times, I am not very satisfied with the result, the table functions of tradingview are not flexible enough to do everything I would like to do.
There are now inputs that manage the appearance of both tables.)
-Data alignment
Notes de version
- Added a delimitation on the table type Daily
Notes de version
- Corrected a display in the Daily table
Notes de version
- Corrected a wrong color in the Daily table
Notes de version
- The space between the title and the result is as close as possible to the one of MarketSmith
- Changed the presentation graphique
Notes de version
- Arranged the | on the Daily Table not to appear when Table Border is set to 1
Notes de version
- Added max_albels_count = 500 to display more historical arrows on the graph
- Organized the alignment of the column (Surprise, ROE, GM)
- Used another method for sales and EPS to have as much historical data as possible, currently 3 variations in % on IOT against only one before
Notes de version
- Modified the Sales Growth YOY method calculation to display more data on IPO.
Impressive results for example on IOT where we can display 4 additional lines compared to the previous method
Notes de version
- Corrected the way to detect a duplicate in the recent sales announcement
Notes de version
- Corrected the case where sales number where the new sales figure was updated and not the % change for recent earning
Notes de version
- Corrected a minor bug that occured when two earnings where close one to another and we had the same % variation. Now the code detects it and recalculate the variation.
Notes de version
- Modified the order of the table Size selection in the input
Notes de version
- Added customisable table border and frame
- Corrected the Gross Margin and Return on Equity offset
Notes de version
- The oppocity of the weekly table is now working. Thank you bognog for pointing the issue.
Notes de version
- Corrected shifting color to transparant of the daily table
- Now the script runs if don't find fundamental data
Notes de version
- Added Estimates for the very next Earning to come
- YoY and QoQ can be viewed separately
- We can now view the QoQ %Change on arrows
- EPS Due date has been added on HeadBand type table
- Default setting now show the Surprise variation
- Reorganised inputs
- Changed the look of the table toward new 'MarketSurge' type look
Notes de version
- Corrected wrong digit on the 'versus' display on sales after B_Kaminski pointed it out
Notes de version
- Corrected the display of # and N/A for estimates
- Simplified the # and N/A System detection
- Added # system as an input option
- Added Quick pre-designed looks based on MarketSmith and MarketSurge Tables
- Corrected GM and ROE estimations values from 0% towards -
- Made the display of variation% of EPS & Sales without arrows as an option
Notes de version
- Corrected the MarketSurge Type Table Look
- Added the variation when negative EPS by default
Notes de version
- Corrected Minor Mistake of # when next EPS quarter was negative calculated against negative EPS. Now display the same value without '#' as MarketSurge does
Notes de version
- Like MarketSurge does, when a reported EPS number is missing the code will now search for the standard EPS for replacement.
This will allow tickers like SEZL and CAVA to be closer to the MarketSurge result.
Moreover it should make the script usable for the Indian Market.
Notes de version
- Modified the style of the table toward MarketSurge look
- Used lighter grey for the MarketSmith table
canslimearningEarningsEPSFundamental AnalysisGrowthibdmarketsmithmarketsurgeoneilquartersales

Script open-source

Dans le plus pur esprit TradingView, l'auteur de ce script l'a publié en open-source, afin que les traders puissent le comprendre et le vérifier. Bravo à l'auteur! Vous pouvez l'utiliser gratuitement, mais la réutilisation de ce code dans une publication est régie par nos Règles. Vous pouvez le mettre en favori pour l'utiliser sur un graphique.

Vous voulez utiliser ce script sur un graphique ?


Aussi sur:

Clause de non-responsabilité