如何在正则表达式中替换前瞻?

我写了一个验证输入字符串的正则表达式.它必须至少有8个字符长度(由字母数字和标点字符组成),并且必须至少有一个数字和一个字母字符.所以我想出了正则表达式:
^(?=.*[0-9])(?=.*[a-zA-Z])[a-zA-Z0-9-,._;:]{8,}$

现在我必须用不支持前瞻的语言重写这个正则表达式,我应该如何重写该正则表达式?

有效输入是:

1foo,bar
foo,bar1
1fooobar
foooobar1
fooo11bar
1234x567
a1234567

输入无效:

fooo,bar
1234-567
.1234567
有两种方法.一种是组成一个表达式来处理所有可能的替代方案:
^[a-zA-Z][0-9][a-zA-Z0-9-,._;:]{6,}$
  |
^[a-zA-Z][a-zA-Z0-9-,._;:][0-9][a-zA-Z0-9-,._;:]{5,._;:]{2}[0-9][a-zA-Z0-9-,._;:]{4,}$

这是一个组合的噩梦,但它会起作用.

一种更简单的方法是使用两个表达式两次验证相同的字符串:

^[a-zA-Z0-9-,}$         # check length and permitted characters

[a-zA-Z].*[0-9]|[0-9].*[a-zA-Z]  # check required characters

编辑:@briandfoy正确指出分别搜索每个必需字符会更有效:

[a-zA-Z]                         # check for required alpha

[0-9]                            # check for required digit

相关文章

正则替换html代码中img标签的src值在开发富文本信息在移动端...
正则表达式
AWK是一种处理文本文件的语言,是一个强大的文件分析工具。它...
正则表达式是特殊的字符序列,利用事先定义好的特定字符以及...
Python界一名小学生,热心分享编程学习。
收集整理每周优质开发者内容,包括、、等方面。每周五定期发...