I just wrote a small script to pull hundreds of MAC Addresses from a switch for comparison, however they are formatted as "0025.9073.3014" rather than the standard "00:25:90:73:30:14".
I am stumped on how to convert this, where the best I can come up with is exploding these into pieces at the ".", then breaking them down further into 2 pieces each, then rejoin all parts with ":" separators.
I am okay with hacky methods but this is bothering me because that is a very poor approach. Is there any way to perform this better?
解决方案
A combination of str_replace and preg_replace:
$str = preg_replace('~..(?!$)~', '\0:', str_replace(".", "", $str));
First stripping out the . then adding : after .. two of any characters (?!$) if not at the end.
Or use a capture group and do it without str_replace:
$str = preg_replace('~(..)(?!$)\.?~', '\1:', $str);
There's not much difference in performance.