GitXplorerGitXplorer
s

python-bits

public
12 stars
9 forks
0 issues

Commits

List of commits on branch main.
Unverified
c3052b857b6a7833522254fab26e881ed9507901

example use of pynput

ssmontanaro committed 3 years ago
Unverified
3b9ff2f7dabf459a0a9cd2445ad2421b3ebc0da8

extract SuspendTracker, add some method docstrings

ssmontanaro committed 3 years ago
Unverified
e935ee029995a5fc0dcaf731a247e58a6aa44f54

add suspendtracker.py

ssmontanaro committed 3 years ago
Unverified
b4f1984400396425d822d76f40bdbbc7be63ec58

extracted from watch.py (where it is no longer used)

ssmontanaro committed 3 years ago
Unverified
775627fe1cbd2c0e69a0af8f2b7d7bdcfc219ded

...

ssmontanaro committed 3 years ago
Unverified
90db19d687fe541c39533aad8c94797681d0af81

add a few docstrings

ssmontanaro committed 3 years ago

README

The README file for this repository.

Skip's Python Bits

This repository just contains a bunch of little Python odds-n-ends I used to keep on my now defunct personal website. This page is just a recast of what used to be the index.html file for the Python section of that site. If something looks a bit out-of-date, note the dates!

I use the at(1) command from time-to-time, and everything works well if I just need to run a command a bit in the future on the current day, e.g., "at 21:00". I use it rarely enough, however, that I can never remember the timespec format necessary if the time to execute is some number of days in the future. I always wind up picking through the man page. This simple front-end accepts whatever the dateutil.parser can parse and builds the somewhat baroque timespec which the at(1) command demands.

This is a handy little script to extract columns from a CSV file and/or normalize the structure of a CSV file to compare different versions.

I cleaned this up a bit and brought it a bit more into the 21st century (class exceptions, a simple doctest, use in instead of calling has_key(), etc). (last updated 2010-04-24)

prstat is the Solaris version of top. Where I used to work we used to use top as a crude logging tool, just letting it run with output redirected to a rotating set of logfiles. prstat can almost substitute for top in this context, however it doesn't timestamp its output. prstat-t.py solves that shortcoming. (last updated 2009-09-14)

If you manage a popular mailing list with Mailman these days, you know how hard it can be to review the messages that get held for your review. mmfold.py fetches the review page for a mailing list and presents a more condensed version of the review page in your web browser. The new version accepts password info in the URL. (last updated 2008-06-30)

A colleague wanted to perform a zip operation (Python's zip not the compression program of the same name) in a shell script. So I wrote something for him. Of course, it uses Python's zip() function under the covers.
If you use the dir() function as a cheap instrospection tool, you've probably noticed that it doesn't work very well for exploring package hierarchies. Here's a replacement which roots around in package directories and eggs and lets you know what submodules and packages it contains. (last updated 2008-03-18)

Python 3.x no longer comes with the bsddb185 module. While it's rarely used, it does have some use on systems which still use the Berkeley DB 1.85 library, mostly BSD-derived Unix systems (including Macs). I extracted the module from the current trunk (2.6a0) and stuck it on PyPI.

Python has a couple different file locking APIs. None are portable. The lockfile package implements a cross-platform API and three different classes which use that API. (I no longer maintain the lockfile package.)

[Add or print iCal events](ical.py or todos from the) command line

I use a Powerbook but rarely take it to work. This makes it difficult to manage events and todos with iCal. The appscript module makes it fairly easy to script many Mac OSX applications from Python. ical.py is a fairly simple example of appscript usage. It also relies on the dateutil package to support flexible date/time parsing.

A thread on comp.lang.python got into a discussion of communication between multiple processes. I suggested creation of a class like Python's threaded Queue class. SocketQueue.py is a trivial implementation of the idea. (last updated 2005-09-28)

Way back in the early days of MIME there was mmencode. It was a classical Unix filter. It was small and did one thing well. Somewhere along the way it got replaced by other tools and on my latest web server I found it's not available (at least not without grubbing around for the proper RPM). Here's a simple replacement in Python. It only implements the -q and -u flags and only writes to stdout, but that probably accounts for 99% of the usage. (last updated 2005-08-12)

Someone on comp.lang.python whose name I didn't record came up with this nifty module autoloader. I modified it slightly. (last updated 2005-03-16)

In response to a ConfigParser Shootout I wrote one such little beastie. Its main features are: indentation-based file format, nesting to arbitrary depth, read/write round trip (sans comments at the moment) and attribute-style or dict-style access. (last updated 2004-10-22)

The subject of the behavior of the reload() function came up in comp.lang.python. This trival implementation may cover most of the perceived shortcomings of the builtin reload(). (last updated 2004-03-14)

When dealing with Unicode inputs from various sources you may or may not know how the input is encoded. If you don't know you probably have to guess. This little module demonstrates one set of guesses. You will almost certainly want to modify it for your needs. (last updated 2004-03-01)

Gerrit Holl suggested save() and load() builtins on python-dev. He was thinking about using pickles, but I implemented a simpleminded version using the readline module. Unfortunately, the readline requirement means it won't work on Windows. Feel free to fix that shortcoming. (last updated 2003-12-01)

For long-running calculations, it's nice to have a simple way to display progress. progress.py provides a couple classes to support this. (last updated 2004-01-24)

From time-to-time you really, really, really just want ASCII, as when some spammer sends you a message with the subject, "We cän makë it lönger now" or "keep up th¯e strugglê, get out ¨of that mess" (whatever that means). latscii.py is a simple codec which makes a reasonable attempt to strip accents from Latin-1 letters and map other characters to reasonable ASCII equivalents (such as mapping '¡' to '!'). (last updated 2003-11-11)

The topic of using regular expressions as dictionary keys recently on comp.lang.python. (It's also come up in the past.) I had a need for this, but with dictionaries containing hundreds of keys, all the regular expression matching makes the straightforward implementation a dog. REDict.REDict uses a binary search of the keys to speed things up. has_key() is O(log len(d)) instead of O(len(d)). Using the REDict.FastREDict class, matching is more like O(1). More could probably be done (caching compiled regular expressions or optimizing the large generated regular expressions), but this suffices for the time being. (last updated 2003-10-22)

A recent virus attack left me trying to manually discard a thousand or so messages per day for a Mailman-2.1 list I help administer. I wrote mmdiscard.py to deal with that from the command line. (last updated 2003-10-15)

I wrote this module a long time ago. Use dateutil instead.

2002-11-08. I refer to this during interactive startup (one of the files which gets imported via PYTHONSTARTUP. It's a useful file and also demonstrates how to use the atexit module.

Guido sent me a version of the marshal module written in Python over fifteen years ago. (I no longer remember why.) Once when I encountered a corrupted marshal file I modified it to not raise an exception when encountering an error during load(). Instead it returns what it has accumulated up to that point. Warning: Do not install this as marshal.py! If you do, you will almost certainly live to regret that mistake!

2002-01-23. I recently had a reason to start using asyncore. It's a marvelous package for doing I/O with several network sockets. One of the first things I wanted to do after getting it working was implement alarms. Signal.alarm is ugly and may not work everywhere anyway, so I took advantage of the fact that asyncore uses the timeout feature of select() and poll().

2001-10-14. I listen on occasion to NPR's Sunday Weekend Edition. Perhaps the best segment of the show is the Puzzle run by Will Shortz. On October 7th, 2001, this challenge was posted:

Draw a 4 by 3 box. The object is to fill it with letters spelling 3 four-letter words across and 4 three-letter words reading down. The conditions: your box can not repeat any letters, and it must use all six vowels (a, e, i, o, u, y) once. All words must be uncapitalized, common English words.

The code in nprpuzzle.py solves this problem using a straightforward O(N**3) algorithm. I don't claim it's the best way to approach the problem, but it was a fun diversion for a Sunday. It uses my little progress module to track progress.

2001-08-13. With the coming change to the semantics of integer division you'll probably want to run something like finddiv.py over your code to identify potential trouble spots. It does nothing more than identify lines containing a "/" operator. It doesn't perform any analysis to try and prune the possible list of lines it displays. It does display lines in a format that Emacs's next-error command understands.

The ConstantMap.ConstantMap class can be instantiated from modules of constants to map "magic numbers" back to their names. This is useful when debugging code that returns such numbers. For example, the numeric constant modules generated by the h2py script all map semi-meaningful names to mostly meaningless numbers. ConstantMap allows you to map them back. (last updated 2004-03-07)

This Python script monitors keyboard and mouse activity and enforces work and rest times. It currently only runs on Linux, but it has run on Windows in the past (only directly monitoring mouse activity) and could probably run on the Mac without a lot of effort.

2000-12-22. This module is a Python replacement for the now defunct soundex.c. This module is a merging of separate ones written by Tim Peters and Fred Drake.

2000-10-10. This module reads SYLK files and generates CSV files. Note that it currently has only been tested with files generated from AppleWorks 5.0 on a Mac.

2000-09-27. There are three general sources of memory leaks in long-running Python programs: cyclical objects that reference counting can't reclaim, botches at the low-level malloc interface, and growth of container objects that are reachable, but whose growth you're unaware of. Neil Schemenauer's garbage collector in Python 2.0 does a good job identifying cyclical garbage. This module attacks the hird case. The test case uses the Cache module below.

2000-09-27. Sometimes you need to cache results of long computations or database queries, but don't want your memory consumption to grow without bound. The Cache class subclasses UserDict.UserDict to provide a cache which discards values based on access time.

2000-06-05. This server passes the XML-RPC validation suite as implemented at validator.xmlrpc.com as of June 5th, 2000.

Adding gzip encoding capability to XML-RPC clients and servers

2000-04-19. The instructions in gzip-xmlrpc.txt describe simple mods to XML-RPC servers and clients to allow responses to be encoded using gzip when possible. This can help performance significantly when using XML-RPC over wide area networks. You can also download the version of xmlrpclib.py that I use which includes one or two other mods. It is based on version 0.9.8 of Fredrik Lundh's xmlrpclib package.