Differences between revisions 46 and 47
Revision 46 as of 2011-09-15 13:55:02
Size: 6908
Editor: ip
Comment:
Revision 47 as of 2012-08-18 13:35:55
Size: 7378
Editor: aepj25
Comment: wiki restore 2013-01-23
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
Line 3: Line 4:
This is a page that is devoted to short programs that can perform powerful operations.  The ability to write short programs that are just as powerful as a program written in another language designed to do the same thing.  However, it is sometimes fun to try and write a program in Python that is only one line.  In other languages this would be nearly ''impossible'', but in Python it is a lot easier to do.  The trick is to think up something that will "do a lot with a little."  I, personally, would love to see this page expanded to the point where it needs some sort of organization system.

Thanks for Your Code,
[[JAM]]

This is a page that is devoted to short programs that can perform powerful operations. The ability to write short programs that are just as powerful as a program written in another language designed to do the same thing. However, it is sometimes fun to try and write a program in Python that is only one line. In other languages this would be nearly ''impossible'', but in Python it is a lot easier to do. The trick is to think up something that will "do a lot with a little." I, personally, would love to see this page expanded to the point where it needs some sort of organization system.


Thanks for Your Code, [[JAM|JAM]]
Line 10: Line 13:
Line 12: Line 16:
 * [[JAM/Code/PlatformFinder]] - This program tells you what platform you are using.
 * [[
JAM/Code/ComPYiler]] - This program compiles every .py file in the Python directory.
 * [[Powerful Python One-Liners/Hostname]] - This programs tells you what your hostname is.   <<BR>>

* [[JAM/Code/PlatformFinder|JAM/Code/PlatformFinder]] - This program tells you what platform you are using.
 * [[JAM/Code/
ComPYiler|JAM/Code/ComPYiler]] - This program compiles every .py file in the Python directory.
 * [[Powerful Python One-Liners/Hostname|Powerful Python One-Liners/Hostname]] - This programs tells you what your hostname is.

Line 18: Line 23:

Line 19: Line 26:




Line 22: Line 34:

Line 23: Line 37:




Line 26: Line 45:

Line 28: Line 49:
Line 29: Line 51:

Line 30: Line 54:




Line 33: Line 62:
<<BR>>



Line 38: Line 71:

Line 40: Line 75:
Line 41: Line 77:

Line 45: Line 83:
Line 47: Line 86:



Line 53: Line 96:
I came up  with this one-liner in response to an [[http://linuxgazette.net/issue96/orr.html|article]] that said it couldn't be done as an one-liner in Python.

What this does is replace the substring "at" by "op" on all lines of all files (in place) under the path specified (here, the current path). 


I came up with this one-liner in response to an [[http://linuxgazette.net/issue96/orr.html|article]] that said it couldn't be done as an one-liner in Python.


What this does is replace the substring "at" by "op" on all lines of all files (in place) under the path specified (here, the current path).
Line 58: Line 105:






Line 62: Line 116:
Clearer is:
{{{import os.path; a=[f for f in os.listdir('.') if not os.path.isdir(f)]}}}


Clearer is: {{{import os.path; a=[f for f in os.listdir('.') if not os.path.isdir(f)]}}}
Line 67: Line 123:
Line 69: Line 126:
{{{
python -c "import sys;[sys.stdout.write(' '.join(line.split(' ')[2:])) for line in sys.stdin]" < input.txt 
}}}




{{{
python -c "import sys;[sys.stdout.write(' '.join(line.split(' ')[2:])) for line in sys.stdin]" < input.txt
}}}
Line 74: Line 136:
A related issue is embedding Python into a Makefile.  I had a really long script
that I was trying to cram into a makefile so I automated the process:


A related issue is embedding Python into a Makefile. I had a really long script that I was trying to cram into a makefile so I automated the process:

Line 88: Line 153:
        
Line 98: Line 163:
This script generates a "one-liner" from make's point of view.  
This script generates a "one-liner" from make's point of view.
Line 101: Line 168:




Line 104: Line 176:

Line 108: Line 182:




Line 112: Line 191:
Line 113: Line 193:




Line 117: Line 202:
Line 118: Line 204:




Line 122: Line 213:

== CSV file to json ==





{{{
python -c "import csv,json;print json.dumps(list(csv.reader(open('csv_file.csv'))))"
}}}

Line 123: Line 226:




Line 127: Line 235:
Line 128: Line 237:




Line 132: Line 246:
Line 133: Line 248:




Line 137: Line 257:
Line 138: Line 259:




Line 142: Line 268:
Line 144: Line 271:
This can be used to convert a string into a "url safe" string   
This can be used to convert a string into a "url safe" string



Line 150: Line 282:
Line 151: Line 284:




Line 155: Line 293:
Line 156: Line 295:




Line 160: Line 304:
Line 161: Line 306:
They call it "The Pyed Piper" or pyp.  It's pretty similar to the -c way of executing python, but it imports common modules and has it's own preset variable that help with splitting/joining, line counter, etc. You use pipes to pass information forward instead of nested parentheses, and then use your normal python string and list methods.  Here is an example from the homepage:

Here, we take a linux long listing, capture every other of the 5th through the 10th lines, keep username and file name fields, replace "hello" with "goodbye", capitalize the first letter of every word, and then add the text "is splendid" to the end: 


They call it "The Pyed Piper" or pyp. It's pretty similar to the -c way of executing python, but it imports common modules and has it's own preset variable that help with splitting/joining, line counter, etc. You use pipes to pass information forward instead of nested parentheses, and then use your normal python string and list methods. Here is an example from the homepage:


Here, we take a linux long listing, capture every other of the 5th through the 10th lines, keep username and file name fields, replace "hello" with "goodbye", capitalize the first letter of every word, and then add the text "is splendid" to the end:

Line 167: Line 317:

Line 169: Line 321:
This uses pyp's built-in string and list variables (p  and pp), as well as the variable whitespace  and it's shortcut w, which both represent a list based on splitting each line on whitespace (whitespace = w = p.split()).
The other functions and selection techniques are all standard python. Notice the pipes ("|") are inside the pyp command. 

http://code.google.com/p/pyp/
http://opensource.imageworks.com/?p=pyp

This uses pyp's built-in string and list variables (p and pp), as well as the variable whitespace and it's shortcut w, which both represent a list based on splitting each line on whitespace (whitespace = w = p.split()). The other functions and selection techniques are all standard python. Notice the pipes ("|") are inside the pyp command.


http://code.google.com/p/pyp/ http://opensource.imageworks.com/?p=pyp

Powerful Python One-Liners

This is a page that is devoted to short programs that can perform powerful operations. The ability to write short programs that are just as powerful as a program written in another language designed to do the same thing. However, it is sometimes fun to try and write a program in Python that is only one line. In other languages this would be nearly impossible, but in Python it is a lot easier to do. The trick is to think up something that will "do a lot with a little." I, personally, would love to see this page expanded to the point where it needs some sort of organization system.

Thanks for Your Code, JAM

Of course, there is debate on whether one-liners are even Pythonic.

Contributed Code

Some thoughts by ewo:

  • Want to know many bytes a terabyte is? If you know further abbreviations, you can extend the list.

import pprint;pprint.pprint(zip(('Byte', 'KByte', 'MByte', 'GByte', 'TByte'), (1 << 10*i for i in xrange(5))))
  • And what's the largest number that can be represented by 8 Byte?

print '\n'.join("%i Byte = %i Bit = largest number: %i" % (j, j*8, 256**j-1) for j in (1 << i for i in xrange(8)))

Cute, isn't it?

Set of all subsets

  • Function that returns the set of all subsets of its argument

f = lambda x: [[y for j, y in enumerate(set(x)) if (i >> j) & 1] for i in range(2**len(set(x)))]

>>>f([10,9,1,10,9,1,1,1,10,9,7])
[[], [9], [10], [9, 10], [7], [9, 7], [10, 7], [9, 10, 7], [1], [9, 1], [10, 1], [9, 10, 1], [7, 1], [9, 7, 1], [10, 7, 1], [9, 10, 7, 1]]

-RJW

Alternately (shorter, more functional version):

f = lambda l: reduce(lambda z, x: z + [y + [x] for y in z], l, [[]])

Decode a base64 encoded file

import base64, sys; base64.decode(open(sys.argv[1], "rb"), open(sys.argv[2], "wb"))

Editing a list of files in place

I came up with this one-liner in response to an article that said it couldn't be done as an one-liner in Python.

What this does is replace the substring "at" by "op" on all lines of all files (in place) under the path specified (here, the current path).

  • Caution: Don't run this on your home directory or you're going to get all your text files edited.

   1 import sys,os,re,fileinput;a=[i[2] for i in os.walk('.') if i[2]] [0];[sys.stdout.write(re.sub('at','op',j)) for j in fileinput.input(a,inplace=1)]

Clearer is: import os.path; a=[f for f in os.listdir('.') if not os.path.isdir(f)]

Reimplementing cut

Print every line from an input file but remove the first two fields.

python -c "import sys;[sys.stdout.write(' '.join(line.split(' ')[2:])) for line in sys.stdin]" < input.txt

Cramming Python into Makefiles

A related issue is embedding Python into a Makefile. I had a really long script that I was trying to cram into a makefile so I automated the process:

import sys,re

def main():
    fh = open(sys.argv[1],'r')
    lines = fh.readlines()
    print '\tpython2.2 -c "`printf \\"if 1:\\n\\'
    for line in lines:
        line = re.sub('[\\\'\"()]','\\\g<0>',line)
        # grab leading white space (should be multiples of 4) and makes them into
        # tabs
        wh_spc_len = len(re.match('\s*',line).group())

        sys.stdout.write('\t')
        sys.stdout.write(wh_spc_len/4*'\\t'+line.rstrip().lstrip())
        sys.stdout.write('\\n\\\n')
    print '\t\\"`"'

if __name__=='__main__':
    main()

This script generates a "one-liner" from make's point of view.

echo unicode character:

python -c "print unichr(234)"

This script echos "ê"

Apply regular expression to lines from stdin

[another command] | python -c "import sys,re;[sys.stdout.write(re.sub('PATTERN', 'SUBSTITUTION', line)) for line in sys.stdin]"

Modify lines from stdin using map

python -c "import sys; tmp = lambda x: sys.stdout.write(x.split()[0]+'\t'+str(int(x.split()[1])+1)+'\n'); map(tmp, sys.stdin);"

Display List of all users on Unix-like systems

print '\n'.join(line.split(":",1)[0] for line in open("/etc/passwd"))

CSV file to json

python -c "import csv,json;print json.dumps(list(csv.reader(open('csv_file.csv'))))"

Compress CSS file

python -c 'import re,sys;print re.sub("\s*([{};,:])\s*", "\\1", re.sub("/\*.*?\*/", "", re.sub("\s+", " ", sys.stdin.read())))'

Decode string written in Hex

python -c "print ''.join(chr(int(''.join(i), 16)) for i in zip(*[iter('474e552773204e6f7420556e6978')]*2))"

Retrieve content text from HTTP data

python -c "import sys; print sys.stdin.read().replace('\r','').split('\n\n',2)[1]";

Prints file extension

print '~/python/one-liners.py'.split('.')[-1]

Escapes content from stdin

This can be used to convert a string into a "url safe" string

python -c "import urllib, sys ; print urllib.quote_plus(sys.stdin.read())";

Reverse lines in stdin

python -c "import sys; print '\n'.join(reversed(sys.stdin.read().split('\n')))"

python -c "import sys; sys.stdout.write(''.join(sys.stdin.readlines()[:10]))" < /path/to/your/file

Sony's Open Source command line tool for performing python one liners using unix-like pipes

They call it "The Pyed Piper" or pyp. It's pretty similar to the -c way of executing python, but it imports common modules and has it's own preset variable that help with splitting/joining, line counter, etc. You use pipes to pass information forward instead of nested parentheses, and then use your normal python string and list methods. Here is an example from the homepage:

Here, we take a linux long listing, capture every other of the 5th through the 10th lines, keep username and file name fields, replace "hello" with "goodbye", capitalize the first letter of every word, and then add the text "is splendid" to the end:

ls -l | pyp "pp[5:11:2] | whitespace[2], w[-1] | p.replace('hello','goodbye') | p.title(),'is splendid'"

and the explanation:

This uses pyp's built-in string and list variables (p and pp), as well as the variable whitespace and it's shortcut w, which both represent a list based on splitting each line on whitespace (whitespace = w = p.split()). The other functions and selection techniques are all standard python. Notice the pipes ("|") are inside the pyp command.

http://code.google.com/p/pyp/ http://opensource.imageworks.com/?p=pyp

Powerful Python One-Liners (last edited 2023-07-19 19:23:56 by HermannStammWilbrandt)

Unable to edit the page? See the FrontPage for instructions.