Alfred workflow with handy string transforming tools.
Use keyword string
(or custom keyword) to init String Multitool. Provide string as an argument and select needed transformation from list.
You can also chain transformations by providing transformation commands after /
char.
For example:
Some string THat we need to use as variable Name! /lc
/lc
command lowercases the string and then camelcases it yielding the result:
someStringThatWeNeedToUseAsVariableName
Lowercase all chars.
SAY HELLO TO MY LITTLE FRIEND! /l
→ say hello to my little friend!
Uppercase all chars.
Can you hear me, Major Tom? /u
→ CAN YOU HEAR ME, MAJOR TOM?
Convert string to pascalcase and remove all non-word and non-digit chars.
The quick brown fox jumps over the lazy dog /p
→ TheQuickBrownFoxJumpsOverTheLazyDog
Convert string to camelcase and remove all non-word and non-digit chars.
is error state! /c
→ isErrorState
Convert string to snakecase and remove all non-word and non-digit chars.
is error state! /s
→ is_error_state
Remove space-like chars from start and end of the string.
Well, something is happening... /t
→ Well, something is happening...
Capitalize first char of each word.
The quick brown fox jumps over the lazy dog /a
→ The Quick Brown Fox Jumps Over The Lazy Dog
Encode URI by replacing certain characters with UTF-8 escape sequences.
https://mozilla.org/?x=шеллы /e
→ https://mozilla.org/?x=%D1%88%D0%B5%D0%BB%D0%BB%D1%8B
See encodeURI
on MDN
Inverse of /e
.
https://mozilla.org/?x=%D1%88%D0%B5%D0%BB%D0%BB%D1%8B /d
→ https://mozilla.org/?x=шеллы
See decodeURI
on MDN
Reverse string.
Remove all non-word and non-digit chars and merge words with specified replacement string. If no replacement argument is provided, Slugify uses -
char as an argument.
http://foo.bar/baz/brrr /S '+'
→ http+foo+bar+baz+brrr
Replace all substring occurences with replacement string. If no replacement argument is provided, Replace uses empty string as an argument.
I'm Will, Will's son /R 'Will' 'Bill'
→ I'm Bill, Bill's son
Prettify your JSON and format it with custom indentation. indent argument takes either number of spaces or 't' for tab indentation. If no argument is provided, 2 spaces used as a default value.
{"name":"George", "occupation":"dentist"} /J '4'
↓
{
"name": "George",
"occupation": "dentist"
}