]> code.delx.au - monosys/blobdiff - bin/passwdgen
python3 conversions
[monosys] / bin / passwdgen
index b72865f01d929247c2d5c88c2d1c25c142dd445b..f7743818cc8c1c23d6116bb665a85ee0cbc02919 100755 (executable)
@@ -1,23 +1,33 @@
-#!/usr/bin/env python
+#!/usr/bin/python3
 
-import random, string, sys
+import random, sys
 
-chars = filter(lambda c: c.isalnum(), map(chr, range(256)))
-chars = chars * 2
-chars += "!@#%^&*(){}[]/=?+_-;:,.<>"
-
-def generate(length):
-       return "".join([random.choice(chars) for i in xrange(length)])
-
-if __name__ == "__main__":
-       try:
-               n = int(sys.argv[1])
-       except:
-               print "Usage: %s length" % sys.argv[0]
-               sys.exit(1)
-
-       print generate(n)
+alnum_chars = list(filter(lambda c: c.isalnum(), map(chr, range(128))))
+full_chars = alnum_chars * 2 + list("!@#%^&*(){}[]/=?+_-;:,.<>")
 
+def generate(chars, length):
+    return "".join([random.choice(chars) for i in range(length)])
 
+def print_usage():
+    print("Usage: %s [length] [alnum|full]" % sys.argv[0])
+    sys.exit(1)
 
+if __name__ == "__main__":
+    if len(sys.argv) <= 1:
+        n = 20
+    elif sys.argv[1].isdigit():
+        n = int(sys.argv[1])
+    else:
+        print_usage()
+
+    if len(sys.argv) <= 2:
+        chars = alnum_chars
+    elif sys.argv[2] == "alnum":
+        chars = alnum_chars
+    elif sys.argv[2] == "full":
+        chars = full_chars
+    else:
+        print_usage()
+
+    print(generate(chars, n))