views:

1091

answers:

12

I've got some experience with Bash, which I don't mind, but now that I'm doing a lot of Windows development I'm needing to do basic stuff/write basic scripts using the Windows command-line language. For some reason said language really irritates me, so I was considering learning Python and using that instead.

Is Python suitable for such things? Moving files around, creating scripts to do things like unzipping a backup and restoring a SQL database, etc.

+12  A: 

Python is well suited for these tasks, and I would guess much easier to develop in and debug than Windows batch files.

The question is, I think, how easy and painless it is to ensure that all the computers that you have to run these scripts on, have Python installed.

gnud
pretty easy to convert python into a .exe. On windows it also has good links to COM and Windows services
Martin Beckett
+5  A: 

Are you aware of PowerShell?

bdukes
+5  A: 

Sure, python is a pretty good choice for those tasks (I'm sure many will recommend PowerShell instead).

Here is a fine introduction from that point of view:

http://www.redhatmagazine.com/2008/02/07/python-for-bash-scripters-a-well-kept-secret/

EDIT: About gnud's concern: http://www.portablepython.com/

Vinko Vrsalovic
+2  A: 

Python is certainly well suited to that. If you're going down that road, you might also want to investigate SCons which is a build system itself built with Python. The cool thing is the build scripts are actually full-blown Python scripts themselves, so you can do anything in the build script that you could otherwise do in Python. It makes make look pretty anemic in comparison.

Upon rereading your question, I should note that SCons is more suited to building software projects than to writing system maintenance scripts. But I wouldn't hesitate to recommend Python to you in any case.

Greg Hewgill
+3  A: 

Anything is a good replacement for the Batch file system in windows. Perl, Python, Powershell are all good choices.

Nick
+3  A: 

@BKB definitely has a valid concern. Here's a couple links you'll want to check if you run into any issues that can't be solved with the standard library:

  • Pywin32 is a package for working with low-level win32 APIs (advanced file system modifications, COM interfaces, etc.)
  • Tim Golden's Python page: he maintains a WMI wrapper package that builds off of Pywin32, but be sure to also check out his "Win32 How Do I" page for details on how to accomplish typical Windows tasks in Python.
technomalogical
A: 

I've been using a lot of Windows Script Files lately. More powerful than batch scripts, and since it uses Windows scripting, there's nothing to install.

Patrick Cuff
+1  A: 

Python, along with Pywin32, would be fine for Windows automation. However, VBScript or JScript used with the Winows Scripting Host works just as well, and requires nothing additional to install.

Bullines
A: 

As much as I love python, I don't think it a good choice to replace basic windows batch scripts.

I can't see see someone having to import modules like sys, os or getopt to do basic things you can do with shell like call a program, check environment variable or an argument.

Also, in my experience, goto is much easier to understand to most sysadmins than a function call.

Kozyarchuk
I find that the explicit os.this and sys.that is an advantage of Python. The shell's random collection of features is hard to get a mental grip on. Python's libraries make it easier to understand.
S.Lott
I would have to agree with S. Lott on this.It is not much extra work and the explicitness keeps the global namespace from being cluttered.
Paul D. Eden
A: 

I've done a decent amount of scripting in both Linux/Unix and Windows environments, in Python, Perl, batch files, Bash, etc. My advice is that if it's possible, install Cygwin and use Bash (it sounds from your description like installing a scripting language or env isn't a problem?). You'll be more comfortable with that since the transition is minimal.

If that's not an option, then here's my take. Batch files are very kludgy and limited, but make a lot of sense for simple tasks like 'copy some files' or 'restart this service'. Python will be cleaner, easier to maintain, and much more powerful. However, the downside is that either you end up calling external applications from Python with subprocess, popen or similar. Otherwise, you end up writing a bunch more code to do things that are comparatively simple in batch files, like copying a folder full of files. A lot of this depends on what your scripts are doing. Text/string processing is going to be much cleaner in Python, for example.

Lastly, it's probably not an attractive alternative, but you might also consider VBScript as an alternative. I don't enjoy working with it as a language personally, but if portability is any kind of concern then it wins out by virtue of being available out of the box in any copy of Windows. Because of this I've found myself writing scripts that were unwieldy as batch files in VBScript instead, since I can't usually depend on Python or Perl or Bash being available on Windows.

Jay
"copying a folder full of files" - a standard module `shutil` could help.
J.F. Sebastian
+5  A: 

Summary

Windows: no need to think, use Python. Unix: quick or run-it-once scripts are for Bash, serious and/or long life time scripts are for Python.

The big talk

In a Windows environment, Python is definitely the best choice since cmd is crappy and PowerShell has not really settled yet. What's more Python can run on several platform so it's a better investment. Finally, Python has a huge set of library so you will almost never hit the "god-I-can't-do-that" wall. This is not true for cmd and PowerShell.

In a Linux environment, this is a bit different. A lot of one liners are shorter, faster, more efficient and often more readable in pure Bash. But if you know your quick and dirty script is going to stay around for a while or will need to be improved, go for Python since it's far easier to maintain and extend and you will be able to do most of the task you can do with GNU tools with the standard library. And if you can't, you can still call the command-line from a Python script.

And of course you can call Python from the shell using -c option:

python -c  "for line in open('/etc/fstab') : print line"

Some more literature about Python used for system administration tasks:

e-satis
A: 

As a follow up, after some experimentation the thing I've found Python most useful for is any situation involving text manipulation (yourStringHere.replace(), regexes for more complex stuff) or testing some basic concept really quickly, which it is excellent for.

For stuff like SQL DB restore scripts I find I still usually just resort to batch files, as it's usually either something short enough that it actually takes more Python code to make the appropriate system calls or I can reuse snippets of code from other people reducing the writing time to just enough to tweak existing code to fit my needs.

As an addendum I would highly recommend IPython as a great interactive shell complete with tab completion and easy docstring access.

Lawrence Johnston