Is there a way to get VBA to pause and wait for TR and RSearch formulas to update?
Basically I am trying to write a macro that loops through a list of RIC's.
In the worksheet every time the RIC is updated, the TR and RSearch functions in there need to update, the sheet needs to recalculate and then some of the results get posted to a report that the VBA macro handles later on. My problem is that if I just let the macro run then the loop continues to the end of the list of RICs before any of the cells in the worksheet have time to update. If I pause the macro, it just sits there, and the TR and RSearch fields never get updated.
I am told that due to the asynchronous nature of the TR API, it is not possible to do this within a single macro, so I am wondering if there is some kind of workaround for this? - or do I need to let the user wait for the updates to happen, and then "manually" click a button that picks the next RIC in the list and so on?
Best Answer
-
@PeterG, I do not believe that you can achieve this in a manner that will produce sustainable solution.
Since you need to control the stages of execution, I suggest that you use the COM API for search (RSearch), real-time data (AdfinX Real-time), analytics (Adfin Analytics), time series (RHistory) and reference data (DEX2).
All the tutorials can be found here.
0
Answers
-
Could you provide more details on this please?
If you are using AdfinX Real-time, you have streaming updates, and your OnUpdate() event handler will be called each time there is an update on the RIC that you subscribe to.
Here is the tutorial that walks you through this process, check out the sample that uses RT_MODE_ONUPDATE parameter on start.
0 -
If you need to run discrete calculations, there are several ways to do that:
- Start AdxRtList subscription with the RT_MODE_ONUPDATE parameter and check on the data only when you need it with ListItems() and ListFields() functions;
- Start AdxRtList in the snapshot mode with RT_MODE_ONIMAGE and get the response only once.
0 - Start AdxRtList subscription with the RT_MODE_ONUPDATE parameter and check on the data only when you need it with ListItems() and ListFields() functions;
Categories
- All Categories
- 3 Polls
- 6 AHS
- 36 Alpha
- 166 App Studio
- 6 Block Chain
- 4 Bot Platform
- 18 Connected Risk APIs
- 47 Data Fusion
- 34 Data Model Discovery
- 685 Datastream
- 1.4K DSS
- 620 Eikon COM
- 5.2K Eikon Data APIs
- 10 Electronic Trading
- Generic FIX
- 7 Local Bank Node API
- 3 Trading API
- 2.9K Elektron
- 1.4K EMA
- 254 ETA
- 557 WebSocket API
- 38 FX Venues
- 14 FX Market Data
- 1 FX Post Trade
- 1 FX Trading - Matching
- 12 FX Trading – RFQ Maker
- 5 Intelligent Tagging
- 2 Legal One
- 23 Messenger Bot
- 3 Messenger Side by Side
- 9 ONESOURCE
- 7 Indirect Tax
- 60 Open Calais
- 276 Open PermID
- 44 Entity Search
- 2 Org ID
- 1 PAM
- PAM - Logging
- 6 Product Insight
- Project Tracking
- ProView
- ProView Internal
- 22 RDMS
- 1.9K Refinitiv Data Platform
- 662 Refinitiv Data Platform Libraries
- 4 LSEG Due Diligence
- LSEG Due Diligence Portal API
- 4 Refinitiv Due Dilligence Centre
- Rose's Space
- 1.2K Screening
- 18 Qual-ID API
- 13 Screening Deployed
- 23 Screening Online
- 12 World-Check Customer Risk Screener
- 1K World-Check One
- 46 World-Check One Zero Footprint
- 45 Side by Side Integration API
- 2 Test Space
- 3 Thomson One Smart
- 10 TR Knowledge Graph
- 151 Transactions
- 143 REDI API
- 1.8K TREP APIs
- 4 CAT
- 27 DACS Station
- 121 Open DACS
- 1.1K RFA
- 104 UPA
- 193 TREP Infrastructure
- 229 TRKD
- 917 TRTH
- 5 Velocity Analytics
- 9 Wealth Management Web Services
- 90 Workspace SDK
- 11 Element Framework
- 5 Grid
- 18 World-Check Data File
- 1 Yield Book Analytics
- 46 中文论坛