|   | PlaceholdersKeePass supports various placeholders. | 
In many places in KeePass (auto-type, URL field, triggers, ...), placeholders can be used.
 Entry Field Placeholders
  Entry Field Placeholders| Placeholder | Field | 
|---|---|
| {TITLE} | Title | 
| {USERNAME} | User name | 
| {URL} | URL | 
| {PASSWORD} | Password | 
| {NOTES} | Notes | 
{S:Name}.
For example, if you have a custom string named "eMail",
you can use the placeholder {S:eMail}.
| Placeholder | Is Replaced By | 
|---|---|
| {URL:RMVSCM} | Entry URL without scheme name. | 
| {URL:SCM} | Scheme name of the entry URL. | 
| {URL:HOST} | Host component of the entry URL. | 
| {URL:PORT} | Port number of the entry URL. | 
| {URL:PATH} | Path component of the entry URL. | 
| {URL:QUERY} | Query information of the entry URL. | 
 Entry Field References
  Entry Field ReferencesFields of other entries can be inserted using Field References.
 Paths and Date/Time Placeholders
  Paths and Date/Time Placeholders| Placeholder | Is Replaced By | 
|---|---|
| {INTERNETEXPLORER} | Path of Internet Explorer, if installed. | 
| {FIREFOX} | Path of Mozilla Firefox, if installed. | 
| {OPERA} | Path of Opera, if installed. | 
| {GOOGLECHROME} | Path of Google Chrome (or Chromium on Unix-like systems), if installed. | 
| {SAFARI} | Path of Safari, if installed. | 
| Placeholder | Is Replaced By | 
|---|---|
| {APPDIR} | KeePass application directory path. | 
| Placeholder | Is Replaced By | 
|---|---|
| {GROUP} | Name of the entry's parent group. | 
| {GROUPPATH} | Full group path of the entry. | 
| {DB_PATH} | Full path of the current database. | 
| {DB_DIR} | Directory of the current database. | 
| {DB_NAME} | File name (including extension) of the current database. | 
| {DB_BASENAME} | File name (excluding extension) of the current database. | 
| {DB_EXT} | File name extension of the current database. | 
| {ENV_DIRSEP} | Directory separator ('\' on Windows, '/' on Unix). | 
| {ENV_PROGRAMFILES_X86} | This is %ProgramFiles(x86)%, if it exists, otherwise%ProgramFiles%. | 
| Placeholder | Is Replaced By | 
|---|---|
| {DT_SIMPLE} | Current local date/time as a simple, sortable string. For example, for 2012-07-25 17:05:34 the value is 20120725170534. | 
| {DT_YEAR} | Year component of the current local date/time. | 
| {DT_MONTH} | Month component of the current local date/time. | 
| {DT_DAY} | Day component of the current local date/time. | 
| {DT_HOUR} | Hour component of the current local date/time. | 
| {DT_MINUTE} | Minute component of the current local date/time. | 
| {DT_SECOND} | Seconds component of the current local date/time. | 
| {DT_UTC_SIMPLE} | Current UTC date/time as a simple, sortable string. | 
| {DT_UTC_YEAR} | Year component of the current UTC date/time. | 
| {DT_UTC_MONTH} | Month component of the current UTC date/time. | 
| {DT_UTC_DAY} | Day component of the current UTC date/time. | 
| {DT_UTC_HOUR} | Hour component of the current UTC date/time. | 
| {DT_UTC_MINUTE} | Minute component of the current UTC date/time. | 
| {DT_UTC_SECOND} | Seconds component of the current UTC date/time. | 
 Environment Variables
  Environment VariablesSystem environment variables are supported.
The name of the variable must be enclosed in '%' characters.
For example %TEMP% is replaced by the user's temporary path.
 Text Transformations
  Text Transformations| Placeholder | Action | 
|---|---|
| {T-REPLACE-RX:/Text/Search/Replace/} | Searches the regular expression Search in Text and replaces all matches by Replace. See below. | 
| {T-CONV:/Text/Type/} | Convert Text to Type. See below. | 
{T-REPLACE-RX:/Text/Search/Replace/} – Replace
Using Regular Expression::' specifies the
separator character. Any character except '}' can be used as separator
character.
It must not appear within the parameters.
For example,
{T-REPLACE-RX:/A/B/C/} and
{T-REPLACE-RX:!A!B!C!} are equivalent.
The last separator character (before the '}') is required.myname@myprovider.net' and
the URL field '{T-REPLACE-RX:!{USERNAME}!.*@(.*)!http://$1!}'.
When running the URL field, KeePass opens
'http://myprovider.net'.
{T-CONV:/Text/Type/} – Convert:Bob' and
the URL field 'http://myprovider.net/?user={T-CONV:/{USERNAME}/L/}'.
When running the URL field, KeePass opens
'http://myprovider.net/?user=bob'.
 Other Placeholders
  Other Placeholders| Placeholder | Action | 
|---|---|
| {PICKCHARS}{PICKCHARS:Fld:Opt} | Shows a dialog to pick certain characters from an entry string. See below. | 
| {NEWPASSWORD} | Generates a new password. See below. | 
| {PASSWORD_ENC} | Password in encrypted form. See below. | 
| {HMACOTP} | Generates a one-time password. See below. | 
| {C:Comment} | Comment; is removed. | 
{PICKCHARS} – Picking Characters: The
The {PICKCHARS} placeholder shows a dialog, in which you can
pick characters of an entry string (like the password) at certain positions.{PICKCHARS} without any parameters lets you pick an arbitrary
amount of characters from the password of the entry.
A different entry string can be specified by appending a ':'
and the name of the field; e.g. {PICKCHARS:UserName}.
The names of the standard fields are Title, UserName (without a space),
Password, URL and Notes. A custom entry string can
be referenced by its name (without an S: prefix).:'. If you want to specify
multiple options, separate them by a comma ','. Options are
key-value pairs, separated by a '='. The following options
are supported:
Conv=D, Conv-Offset=1,
then '2', 'c' and 'C' are converted to 3 down arrow keypresses.Conv=D, Conv-Fmt=0A.
Similarly, if it contains values A-Z0-9, specify Conv=D, Conv-Fmt=A0.
If digits start with 1 instead of 0 (i.e. the 0 appears after the 9), use
1A and A1 instead of 0A and A0.{USERNAME}{TAB}{PICKCHARS:Password:C=5}{ENTER} 
{S:Memorable}{TAB}{PICKCHARS:Password:ID=1, C=1, Conv=D,
Conv-Offset=1}{TAB}{PICKCHARS:Password:ID=2, C=1, Conv=D,
Conv-Offset=1}{TAB}{PICKCHARS:Password:ID=3, C=1, Conv=D,
Conv-Offset=1}{ENTER}{S:Memorable}{TAB}{PICKCHARS:Password:C=3, Conv=D, Conv-Offset=1},
all the down arrow keypresses are sent to the same, currently active control.{DELAY 250} after each {TAB},
or slowing down the whole sequence, e.g. by prepending {DELAY=150}.
{NEWPASSWORD} – Generating New Passwords:{NEWPASSWORD} placeholder
generates a new password for the current entry, based on the "Automatically
generated passwords for new entries" generator profile.{PASSWORD}{TAB}{NEWPASSWORD}{TAB}{NEWPASSWORD}{ENTER}
as auto-type sequence.
{PASSWORD_ENC} – Encrypting Passwords:{PASSWORD_ENC} placeholder is replaced by the password
of the current entry in encrypted form. The password is encrypted using
credentials of the current Windows user. The encrypted password should
not be stored and only works for the current user.-pw-enc command line parameter
(see the URL Field Capabilities page for
an example how to define an URL to open an additional KeePass database).
The placeholder cannot be used to transfer passwords to other applications
(except KeePass), because the target applications don't know how to decrypt
encrypted passwords generated by {PASSWORD_ENC}.
{HMACOTP} – Generating One-Time Passwords:{HMACOTP} placeholder
generates a HMAC-based one-time password as specified in RFC 4226.
The shared secret is the UTF-8 representation of the value of the
'HmacOtp-Secret' custom entry string field
(case-sensitive), and
the counter is stored in decimal form in the 'HmacOtp-Counter' field.{HMACOTP}
placeholder, switch to the 'Advanced' tab, add a string named
HmacOtp-Secret with value 12345678901234567890,
and add a string named HmacOtp-Counter with value 0.
When you now double-click onto the password cell of the entry in the
entry list of the main window, an OTP is copied to the
clipboard. When auto-typing, an OTP is sent as password.
Each time you perform such an action, KeePass updates the counter value.
With the secret key and counter values above, the following OTPs
are generated: 755224, 287082, 359152, 969429, 338314, ...
(more generated OTPs can be found in the example in RFC 4226).