Is it possible to return how many times my macro has been used over hundreds of files?

Bassie

Board Regular
Joined
Jan 13, 2022
Messages
66
Office Version
  1. 2019
Platform
  1. Windows
Hey,

I would like to release a bunch of macros bundled into an add-in soon and I was wondering if it was possible to track the amount of times each macro has been used and send it back to me. I currently do have the counting of the macros used in place but sending it to me is what I am struggling with as I dont have any experience with that. I was thinking maybe something http related but I would not know where to start.

Any suggestions?

-
Bassie
 

Excel Facts

How to total the visible cells?
From the first blank cell below a filtered data set, press Alt+=. Instead of SUM, you will get SUBTOTAL(9,)
Do you have access to a Web server which allows you to run PHP code? If so, you could create a page which uses PHP to capture the IP address from which the page is load and writes it to a log file on your Web server together with any other information which the page load command passes, for example:-


The PHP might be something like this:-
VBA Code:
<?php
  if (getenv ("HTTP_CLIENT_IP"))
    $ip = getenv ("HTTP_CLIENT_IP");
  else
    if (getenv ("HTTP_X_FORWARDED_FOR"))
      $ip = getenv ("HTTP_X_FORWARDED_FOR");
    else
      if (getenv ("REMOTE_ADDR"))
        $ip = getenv ("REMOTE_ADDR");
      else
        $ip = "UNKNOWN";
  $ip = str_pad ($ip , 15);
  $page = getenv ("HTTP_REFERER");
  date_default_timezone_set ("Europe/London");
  $logfilename = date ("Ymd") . ".log";
  $fh = fopen ("./logs/$logfilename" , "a");
  fwrite ($fh , date ("Y/m/d H:i:s - ") . $ip . " - " . $page . "\n");
  fclose($fh);
  return "";
?>

This produces one log file per day called (for example) 20230505.log but the code can be modified to produce one log file per month or per year instead.

You'd end up with a log file containing entries looking something like this:-

05/05/2023 14:00 192.168.0.1 - http://www.mysite.com/logger.html?filename=somefile.xlsm&macroname=somemacro
05/05/2023 14:20 127.0.0.1 - http://www.mysite.com/logger.html?filename=someotherfile.xlsm&macroname=someothermacro


You could then load the log file into Excel to analyse it.

Is any of this any help?
 
Upvote 0
Solution
Do you have access to a Web server which allows you to run PHP code? If so, you could create a page which uses PHP to capture the IP address from which the page is load and writes it to a log file on your Web server together with any other information which the page load command passes, for example:-


The PHP might be something like this:-
VBA Code:
<?php
  if (getenv ("HTTP_CLIENT_IP"))
    $ip = getenv ("HTTP_CLIENT_IP");
  else
    if (getenv ("HTTP_X_FORWARDED_FOR"))
      $ip = getenv ("HTTP_X_FORWARDED_FOR");
    else
      if (getenv ("REMOTE_ADDR"))
        $ip = getenv ("REMOTE_ADDR");
      else
        $ip = "UNKNOWN";
  $ip = str_pad ($ip , 15);
  $page = getenv ("HTTP_REFERER");
  date_default_timezone_set ("Europe/London");
  $logfilename = date ("Ymd") . ".log";
  $fh = fopen ("./logs/$logfilename" , "a");
  fwrite ($fh , date ("Y/m/d H:i:s - ") . $ip . " - " . $page . "\n");
  fclose($fh);
  return "";
?>

This produces one log file per day called (for example) 20230505.log but the code can be modified to produce one log file per month or per year instead.

You'd end up with a log file containing entries looking something like this:-

05/05/2023 14:00 192.168.0.1 - http://www.mysite.com/logger.html?filename=somefile.xlsm&macroname=somemacro
05/05/2023 14:20 127.0.0.1 - http://www.mysite.com/logger.html?filename=someotherfile.xlsm&macroname=someothermacro


You could then load the log file into Excel to analyse it.

Is any of this any help?

This is great thank you! I am not 100% familiair with it yet but this gives me a very good start to learn something new!
 
Upvote 0

Forum statistics

Threads
1,224,820
Messages
6,181,162
Members
453,021
Latest member
Justyna P

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top