Splunk Search

How to calculate previous week results?

wanda619
Path Finder

Hi community,

I have to calculate previous week result, based on that, I calculate Percent difference with this weeks results. I have following code, but not able to get previous week result right.

My Code : 

| bucket _time span=1w
| lookup table_1 LicenseKey OUTPUT CustomerName
| eval CustomerName=coalesce(CustomerName,LicenseKey)
| stats count as Result by CustomerName, ErrorCode
| eventstats sum(Result) as Total by CustomerName
| eval PercentOfTotal = round((Result/Total)*100,3)
| sort - _time
| streamstats current=f latest(Result) as Result_Prev by CustomerName
| eval PercentDifference = round(((Result/Result_Prev)-1)*100,2)
| fillnull value="0"
| append
[ search index=abc= xyz:123 ErrorCode!=0
| `DedupDHI`
| lookup Table_1 LicenseKey OUTPUT CustomerName
| eval CustomerName=coalesce(CustomerName,LicenseKey)
| stats count as Result by CustomerName
| eval ErrorCode="Total", PercentOfTotal=100]
| fillnull value="0"
| lookup Table_2 ErrorCode OUTPUT Description
| lookup Table_1 LicenseKey OUTPUT CustomerName
| eval CustomerName=coalesce(CustomerName,LicenseKey)
| eval Error=if(ErrorCode!="Total", ErrorCode+" ("+coalesce(Description,"Description Missing - Update Table_2")+")", ErrorCode)
| rename Result_Prev as "Previous Week Results", PercentDifference as " Percent Difference", PercentOfTotal as "Percent of Total"
| fields CustomerName, Error, Result,"Previous Week Results", " Percent Difference" , "Percent of Total"
| sort CustomerName, Error, PercentDifference

Output - 

CustomerName Error Result Previous Week Results  Percent Difference Percent of Total
AIG Private Client Group 1002 (abc) 4 0 0 3.252
AIG Private Client Group 1003 (cxz) 2 4 -50 1.626
AIG Private Client Group 1013 (Invalid Format) 12 4 200 9.756
AIG Private Client Group 1023 (Invalid Name) 3 4 -25 2.439
AIG Private Client Group 1027 (Invalid ) 102 4 2450 82.927
AIG Private Client Group Total 123 0 0 100
AIICO 1023 (Invalid Name) 8 0 0 38.095
AIICO 1201 1 8 -87.5 4.762
AIICO 1305  12 8 50 57.143
AIICO Total 21 0 0 100
Acceptance 1023 (Invalid Name) 3 0 0 27.273
Acceptance 1027 8 3 166.67 72.727
Acceptance Total 11 0 0 100

 

The Previous Week Results column is appending 4, if noticed which is wrong. any suggestions to solve this

0 Karma

bowesmana
SplunkTrust
SplunkTrust

I assume there is more search prior to the bucket command, however, this first part of your search is wrong, you are doing

| bucket _time span=1w
| lookup table_1 LicenseKey OUTPUT CustomerName
| eval CustomerName=coalesce(CustomerName,LicenseKey)
| stats count as Result by CustomerName, ErrorCode
| eventstats sum(Result) as Total by CustomerName
| eval PercentOfTotal = round((Result/Total)*100,3)
| sort - _time

however, you are doing stats count... but do not include _time as a split by field, so you no longer have the _time field available when you do the 'sort - _time' and the stats are not split by week. 

When you use bucket _time span=1w, you then need to do stats ... by _time, A, B...

streamstats also needs global=f and window=1 to do what you are trying to do

 

0 Karma

wanda619
Path Finder

@bowesmana is there any other alternative than using bucket_time span? to acheive the result

0 Karma

bowesmana
SplunkTrust
SplunkTrust

bucket is perfectly valid time span but it will depend on where your data is coming from for each week. In your example you are making one search then appending another. 

If your basic search is the same for both weeks, then I would search something like this

base_search
| bin _time span=1w
| lookup table_1 LicenseKey OUTPUT CustomerName
| eval CustomerName=coalesce(CustomerName,LicenseKey)
| stats count as Result by _time CustomerName, ErrorCode
| streamstats global=f window=1 current=f latest(Result) as prev by CustomerName, ErrorCode
| where isnotnull(prev)
| eval PercentDifference = round(((Result/prev)-1)*100,2)

this basic technique will give you the percentage increase of the previous week.

The where clause removes the rows where there is no previous value, i.e. the previous figures, which are carried forward to the 'next' week. Sorting is not necessary as the stats by _time will order them correctly.

Hope this helps.

wanda619
Path Finder

@bowesmana Correct the basic search is same for both. 

The where clause I believe works but it messes up with the output for Error, as It does not allows me to show all the other error code output. for example - 

CustomerNameErrorResultPrevious Week Results Percent DifferencePercent of Total_time
Client11003 (Invalid Birth Year)12-500.8852022-08-17T00:00:00.000-0500
Client11023 (Invalid Name)12-500.8852022-08-17T00:00:00.000-0500
Client11027 (Invalid UnderwritingState)283-97.591.772022-08-17T00:00:00.000-0500
Client1Total113001001969-12-31T18:00:00.000-0500
Client21023 (Invalid Name)111-90.914.3482022-08-17T00:00:00.000-0500
Client2Total23001001969-12-31T18:00:00.000-0500
Client31027 (Invalid UnderwritingState)110-907.1432022-08-17T00:00:00.000-0500
Client3Total14001001969-12-31T18:00:00.000-0500
Client41013 (Invalid Drivers License Format)18-87.53.8462022-08-17T00:00:00.000-0500
Client4Total26001001969-12-31T18:00:00.000-0500
Client5Total2001001969-12-31T18:00:00.000-0500
Client6Total8001001969-12-31T18:00:00.000-0500
Client7Total1001001969-12-31T18:00:00.000-0500
Client81013 (Invalid Drivers License Format)23-33.331.6812022-08-17T00:00:00.000-0500
Client81023 (Invalid Name)18-87.50.842022-08-17T00:00:00.000-0500
Client81027 (Invalid UnderwritingState)495-95.793.3612022-08-17T00:00:00.000-0500
Client8Total119001001969-12-31T18:00:00.000-0500
Client91013 (Invalid Drivers License Format)15165-90.917.7722022-08-17T00:00:00.000-0500
Client9Total193001001969-12-31T18:00:00.000-0500
Client10Total6001001969-12-31T18:00:00.000-0500
Client11Total1197001001969-12-31T18:00:00.000-0500

 

The Client 5,6,7 as well as 10,11 just shows up with total.

0 Karma

wanda619
Path Finder

@bowesmana or previous week result

0 Karma
Get Updates on the Splunk Community!

Splunk Smartness with Brandon Sternfield | Episode 3

Hello and welcome to another episode of "Splunk Smartness," the interview series where we explore the power of ...

Monitoring Postgres with OpenTelemetry

Behind every business-critical application, you’ll find databases. These behind-the-scenes stores power ...

Mastering Synthetic Browser Testing: Pro Tips to Keep Your Web App Running Smoothly

To start, if you're new to synthetic monitoring, I recommend exploring this synthetic monitoring overview. In ...