-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathVBAWallStreet.vba
87 lines (70 loc) · 4.74 KB
/
VBAWallStreet.vba
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
'Create a VBA script that will loop through all stocks and create a column for:
'1) Total Volume of each Stock’s Sales throughout the year,
'2) Stock’ Ticker Symbol,
'3) Yearly Price Change (Opening price to Closing Price)
'4) Yearly Percent Change (Opening price to Closing Price)
'a. Conditional Format – Positive (Green) & Negative (Red)
'1) Create Table (4x3 as below) W/ Ticker Symbol & Value of:
'a. ‘Greatest % Increase’,
'b. ‘Greatest % Decrease’,
'c. ‘Greatest Total Volume’.
'-------------------------------------------
Sub VBAWallStreet():
Dim Ticker As String
Dim Total_Volume_of_Stock, Yearly_Change, Percent_Change, Opening_Price, Closing_Price As Double
Dim CurrentRow As Integer
For Each ws In Worksheets
CurrentRow = 2 'Begin on 2nd row of each sheet
Total_Volume_of_Stock = 0 'Will maintain sum of unique ticker
Opening_Price = ws.Cells(2, 3)
LastRow = ws.Cells(Rows.Count, 1).End(xlUp).Row 'determine last row of each sheet
For i = 2 To LastRow 'For each row in the WS
'
If ws.Cells(i, 1) <> ws.Cells(i + 1, 1) Then 'IS NEXT TICKER UNIQUE? if so, then TIME TO SUMMARIZE
Ticker = ws.Cells(i, 1) 'COLLECT CURRENT TICKER
Total_Volume_of_Stock = Total_Volume_of_Stock + ws.Cells(i, 7) 'ADD FINAL DAY TO VOLUME SUM
Closing_Price = ws.Cells(i, 6) 'COLLECT FINAL CLOSING PRICE
Yearly_Change = Closing_Price - Opening_Price 'FINAL CLOSING PRICE - INITIAL OPENING PRICE
If Opening_Price = 0 Then
Percent_Change = 0 'EXCEPTION: CANNOT DIVIDE BY 0
Else
Percent_Change = 100 * Yearly_Change / Opening_Price 'CALCULATE PERCENT CHANGE
End If
'SUMMARY:
ws.Range("I" & CurrentRow).Value = Ticker 'TICKER SYMBOL
ws.Range("J" & CurrentRow).Value = Yearly_Change 'CHANGE
ws.Range("K" & CurrentRow).Value = (Percent_Change & "%") '% CHANGE
ws.Range("L" & CurrentRow).Value = Format(Total_Volume_of_Stock, "$#,###") 'VOLUME
Total_Volume_of_Stock = 0 'RESET VOLUME
Opening_Price = ws.Cells(i + 1, 3) 'SET NEW OPENING PRICE FOR NEXT TICKER;
If ws.Range("J" & CurrentRow).Value >= 0 Then 'positive yearly change --> Green
ws.Range("J" & CurrentRow).Interior.ColorIndex = 4
ElseIf ws.Range("J" & CurrentRow).Value < 0 Then
ws.Range("J" & CurrentRow).Interior.ColorIndex = 3 'negative yearly change --> Red
End If
CurrentRow = CurrentRow + 1
Else 'NEXT TICKER IS NOT NEW, SO CONTINUE TO ADD TO CURRENT SUM
Total_Volume_of_Stock = Total_Volume_of_Stock + ws.Cells(i, 7)
End If
Next i
'Column Name Reset + New Column Names;
ws.Range("A1") = "Ticker Symbol"
ws.Range("B1") = "Date"
ws.Range("C1") = "Opening Price"
ws.Range("D1") = "High"
ws.Range("E1") = "Low"
ws.Range("F1") = "Closing Price"
ws.Range("G1") = "Daily Volume"
ws.Range("H1") = "-------"
ws.Range("I1") = "Ticker Symbol"
ws.Range("J1") = "Yearly Change"
ws.Range("K1") = "Percent Change"
ws.Range("L1") = "Total Stock Volume"
Next ws
End Sub
'LOGIC: Done to each sheet
'1) start with new (1st) ticker, & collect initial price (opening), start sum of daily volumes for ticker
'2) Is next ticker new? If no, keep summing daily volumes
'3) If yes, collect final price, make calculations (total change, percent change, total sum of volume)
'3) summarize results for ticker by printing calculations & totals into a new column
'4) Repeat process starting with new ticker ...