<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>
<channel>
	<title>Mad Python &#187; python</title>
	<atom:link href="http://blog.madpython.com/tag/python/feed/" rel="self" type="application/rss+xml" />
	<link>http://blog.madpython.com</link>
	<description>Watch out.. he's angry</description>
	<lastBuildDate>Sat, 17 Jul 2010 19:16:38 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0.1</generator>
		<item>
		<title>Algorithms in Python: Binary Operations</title>
		<link>http://blog.madpython.com/2010/07/17/algorithms-in-python-binary-operations/</link>
		<comments>http://blog.madpython.com/2010/07/17/algorithms-in-python-binary-operations/#comments</comments>
		<pubDate>Sat, 17 Jul 2010 19:08:22 +0000</pubDate>
		<dc:creator>Xavier</dc:creator>
				<category><![CDATA[Computer Science]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[tech]]></category>
		<category><![CDATA[algorithms]]></category>
		<category><![CDATA[CS]]></category>
		<category><![CDATA[programming]]></category>
		<category><![CDATA[python]]></category>
		<guid isPermaLink="false">http://blog.madpython.com/?p=131</guid>
		<description><![CDATA[Today I&#8217;d like to demonstrate a simple implementation of Kenneth Rosen&#8216;s binary addition and multiplication algorithms as outlined in &#34;Discrete Mathematics and its Applications&#34;. Both algorithms are very simple and work the same way we&#8217;ve all learned to do decimal &#8230; <a href="http://blog.madpython.com/2010/07/17/algorithms-in-python-binary-operations/">Continue reading <span class="meta-nav">&#8594;</span></a>
Related posts:<ol><li><a href='http://blog.madpython.com/2010/07/10/algorithms-in-python-base-expansion/' rel='bookmark' title='Permanent Link: Algorithms in Python: Base Expansion'>Algorithms in Python: Base Expansion</a></li>
<li><a href='http://blog.madpython.com/2009/03/07/extending-postgresql-with-python/' rel='bookmark' title='Permanent Link: Extending PostgreSQL with Python'>Extending PostgreSQL with Python</a></li>
</ol>]]></description>
			<content:encoded><![CDATA[<p>Today I&#8217;d like to demonstrate a simple implementation of <a href="http://highered.mcgraw-hill.com/sites/0072880082/information_center_view0/about_the_author.html" onclick="return TrackClick('http%3A%2F%2Fhighered.mcgraw-hill.com%2Fsites%2F0072880082%2Finformation_center_view0%2Fabout_the_author.html','Kenneth+Rosen')" target="_blank">Kenneth Rosen</a>&#8216;s binary addition and multiplication algorithms as outlined in &quot;<a href="http://www.amazon.com/Discrete-Mathematics-Applications-Kenneth-Rosen/dp/0071244743/ref=sr_1_2?ie=UTF8&#038;s=books&#038;qid=1279392073&#038;sr=8-2" onclick="return TrackClick('http%3A%2F%2Fwww.amazon.com%2FDiscrete-Mathematics-Applications-Kenneth-Rosen%2Fdp%2F0071244743%2Fref%3Dsr_1_2%3Fie%3DUTF8%26s%3Dbooks%26qid%3D1279392073%26sr%3D8-2','Discrete+Mathematics+and+its+Applications')" target="_blank">Discrete Mathematics and its Applications</a>&quot;. Both algorithms are very simple and work the same way we&#8217;ve all learned to do decimal additions and multiplications by hand in grade-school.</p>
<p>As usual, I&#8217;ve also provided a unit-test suite for each algorithm.</p>
<p><strong>Please note:</strong> This is only intended to demonstrate the algorithms. If you are actually trying to do some real work with binary numbers in Python, note that the language itself provides a highly optimized implementation of binary numbers and related operations. Here are a few examples:</p>
<div class="wp_syntax"><div class="code"><pre class="python" style="font-family:monospace;"><span style="color: #808080; font-style: italic;"># Decimal to binary conversion:</span>
<span style="color: #66cc66;">&gt;&gt;&gt;</span> bin<span style="color: black;">&#40;</span><span style="color: #ff4500;">15</span><span style="color: black;">&#41;</span>
<span style="color: #483d8b;">'0b1111'</span>
&nbsp;
<span style="color: #808080; font-style: italic;"># Binary to decimal conversion:</span>
<span style="color: #66cc66;">&gt;&gt;&gt;</span> <span style="color: #008000;">str</span><span style="color: black;">&#40;</span>0b1111<span style="color: black;">&#41;</span>
<span style="color: #483d8b;">'15'</span>
&nbsp;
<span style="color: #808080; font-style: italic;"># Binary addition:</span>
<span style="color: #66cc66;">&gt;&gt;&gt;</span> bin<span style="color: black;">&#40;</span>0b1111 + 0b10011<span style="color: black;">&#41;</span>
<span style="color: #483d8b;">'0b100010'</span>
&nbsp;
<span style="color: #808080; font-style: italic;"># Binary multiplication:</span>
<span style="color: #66cc66;">&gt;&gt;&gt;</span> bin<span style="color: black;">&#40;</span>0b1111 <span style="color: #66cc66;">*</span> 0b10011<span style="color: black;">&#41;</span>
<span style="color: #483d8b;">'0b100011101'</span></pre></div></div>
<h2>Binary Addition</h2>
<p>We will use strings in this example to represent sequences of bits. The algorithm operates right-to-left, maintaining a carry each time it adds two 1-valued bits.</p>
<h3>Code:</h3>
<div class="wp_syntax"><div class="code"><pre class="python" style="font-family:monospace;"><span style="color: #483d8b;">&quot;&quot;&quot;Simple binary operation algorithm.&quot;&quot;&quot;</span>
&nbsp;
<span style="color: #ff7700;font-weight:bold;">import</span> <span style="color: #dc143c;">math</span>
&nbsp;
<span style="color: #808080; font-style: italic;"># a and b should be string representation of the binary components</span>
<span style="color: #808080; font-style: italic;"># You could easily extend this to overload the + operator for binaries,</span>
<span style="color: #808080; font-style: italic;"># but this is already built into python.</span>
<span style="color: #ff7700;font-weight:bold;">def</span> binary_addition<span style="color: black;">&#40;</span>bin_a, bin_b<span style="color: black;">&#41;</span>:
    <span style="color: #483d8b;">&quot;&quot;&quot;Performs a binary addition against two provided binary numbers&quot;&quot;&quot;</span>
&nbsp;
    <span style="color: #808080; font-style: italic;"># Pad the components so they are of equal length</span>
    max_length = <span style="color: #008000;">max</span><span style="color: black;">&#40;</span><span style="color: #008000;">len</span><span style="color: black;">&#40;</span>bin_a<span style="color: black;">&#41;</span>, <span style="color: #008000;">len</span><span style="color: black;">&#40;</span>bin_b<span style="color: black;">&#41;</span><span style="color: black;">&#41;</span>
    bin_a, bin_b = bin_a.<span style="color: black;">zfill</span><span style="color: black;">&#40;</span>max_length<span style="color: black;">&#41;</span>, bin_b.<span style="color: black;">zfill</span><span style="color: black;">&#40;</span>max_length<span style="color: black;">&#41;</span>
&nbsp;
&nbsp;
    carry = <span style="color: #ff4500;">0</span>
    result = <span style="color: #483d8b;">''</span>
&nbsp;
    <span style="color: #808080; font-style: italic;"># Note that we work from right to left</span>
    <span style="color: #ff7700;font-weight:bold;">for</span> i <span style="color: #ff7700;font-weight:bold;">in</span> <span style="color: #008000;">range</span><span style="color: black;">&#40;</span><span style="color: #ff4500;">0</span>, max_length<span style="color: black;">&#41;</span><span style="color: black;">&#91;</span>::-<span style="color: #ff4500;">1</span><span style="color: black;">&#93;</span>:
        tmp = <span style="color: #008000;">int</span><span style="color: black;">&#40;</span><span style="color: #dc143c;">math</span>.<span style="color: black;">floor</span><span style="color: black;">&#40;</span><span style="color: black;">&#40;</span><span style="color: #008000;">int</span><span style="color: black;">&#40;</span>bin_a<span style="color: black;">&#91;</span>i<span style="color: black;">&#93;</span><span style="color: black;">&#41;</span> + <span style="color: #008000;">int</span><span style="color: black;">&#40;</span>bin_b<span style="color: black;">&#91;</span>i<span style="color: black;">&#93;</span><span style="color: black;">&#41;</span> + carry<span style="color: black;">&#41;</span>/<span style="color: #ff4500;">2</span><span style="color: black;">&#41;</span><span style="color: black;">&#41;</span>
        res = <span style="color: #008000;">str</span><span style="color: black;">&#40;</span><span style="color: #008000;">int</span><span style="color: black;">&#40;</span>bin_a<span style="color: black;">&#91;</span>i<span style="color: black;">&#93;</span><span style="color: black;">&#41;</span> + <span style="color: #008000;">int</span><span style="color: black;">&#40;</span>bin_b<span style="color: black;">&#91;</span>i<span style="color: black;">&#93;</span><span style="color: black;">&#41;</span> + carry - <span style="color: #ff4500;">2</span><span style="color: #66cc66;">*</span>tmp<span style="color: black;">&#41;</span>
        result += res
        carry = tmp
&nbsp;
    result = <span style="color: black;">&#40;</span>result + <span style="color: #008000;">str</span><span style="color: black;">&#40;</span>carry<span style="color: black;">&#41;</span><span style="color: black;">&#41;</span><span style="color: black;">&#91;</span>::-<span style="color: #ff4500;">1</span><span style="color: black;">&#93;</span>
    <span style="color: #ff7700;font-weight:bold;">try</span>:
        <span style="color: #ff7700;font-weight:bold;">return</span> result<span style="color: black;">&#91;</span>result.<span style="color: black;">index</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">'1'</span><span style="color: black;">&#41;</span>:<span style="color: black;">&#93;</span>
    <span style="color: #ff7700;font-weight:bold;">except</span> <span style="color: #008000;">ValueError</span>, ex:
        <span style="color: #ff7700;font-weight:bold;">return</span> <span style="color: #483d8b;">'0'</span></pre></div></div>
<h3>Unit Test:</h3>
<div class="wp_syntax"><div class="code"><pre class="python" style="font-family:monospace;"><span style="color: #483d8b;">&quot;&quot;&quot;Unit test for binary_addition.py&quot;&quot;&quot;</span>
&nbsp;
<span style="color: #ff7700;font-weight:bold;">import</span> <span style="color: #dc143c;">unittest</span>
<span style="color: #ff7700;font-weight:bold;">from</span> binary_addition <span style="color: #ff7700;font-weight:bold;">import</span> binary_addition
&nbsp;
<span style="color: #ff7700;font-weight:bold;">class</span> TestBinaryAddition<span style="color: black;">&#40;</span><span style="color: #dc143c;">unittest</span>.<span style="color: black;">TestCase</span><span style="color: black;">&#41;</span>:
&nbsp;
    <span style="color: #483d8b;">&quot;&quot;&quot;Comparing python binary addition against our own&quot;&quot;&quot;</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">def</span> test_add_same_length<span style="color: black;">&#40;</span><span style="color: #008000;">self</span><span style="color: black;">&#41;</span>:
&nbsp;
        <span style="color: #483d8b;">&quot;&quot;&quot;Adding 2 binary numbers of the same length&quot;&quot;&quot;</span>
&nbsp;
        bin_a = <span style="color: #483d8b;">'001001101'</span>
        bin_b = <span style="color: #483d8b;">'011011010'</span>
&nbsp;
        <span style="color: #008000;">self</span>._compare_additions<span style="color: black;">&#40;</span>bin_a, bin_b<span style="color: black;">&#41;</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">def</span> test_add_b_larger<span style="color: black;">&#40;</span><span style="color: #008000;">self</span><span style="color: black;">&#41;</span>:
&nbsp;
        <span style="color: #483d8b;">&quot;&quot;&quot; B has more digits than A &quot;&quot;&quot;</span>
&nbsp;
        bin_a = <span style="color: #483d8b;">'01000101'</span>
        bin_b = <span style="color: #483d8b;">'1110010110101011101101011101000101'</span>
&nbsp;
        <span style="color: #008000;">self</span>._compare_additions<span style="color: black;">&#40;</span>bin_a, bin_b<span style="color: black;">&#41;</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">def</span> test_add_b_smaller<span style="color: black;">&#40;</span><span style="color: #008000;">self</span><span style="color: black;">&#41;</span>:
&nbsp;
        <span style="color: #483d8b;">&quot;&quot;&quot;B has less digits than A&quot;&quot;&quot;</span>
&nbsp;
&nbsp;
        bin_a = <span style="color: #483d8b;">'1110001001001001001101101011000101'</span>
        bin_b = <span style="color: #483d8b;">'0110010'</span>
&nbsp;
        <span style="color: #008000;">self</span>._compare_additions<span style="color: black;">&#40;</span>bin_a, bin_b<span style="color: black;">&#41;</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">def</span> _compare_additions<span style="color: black;">&#40;</span><span style="color: #008000;">self</span>, bin_a, bin_b<span style="color: black;">&#41;</span>:
&nbsp;
        <span style="color: #483d8b;">&quot;&quot;&quot;Compares the python implementation against ours&quot;&quot;&quot;</span>
&nbsp;
        bin_add = binary_addition<span style="color: black;">&#40;</span>bin_a, bin_b<span style="color: black;">&#41;</span>
        py_add = bin<span style="color: black;">&#40;</span><span style="color: #008000;">eval</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">&quot;0b%s&quot;</span> <span style="color: #66cc66;">%</span> bin_a<span style="color: black;">&#41;</span> + <span style="color: #008000;">eval</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">&quot;0b%s&quot;</span> <span style="color: #66cc66;">%</span> bin_b<span style="color: black;">&#41;</span><span style="color: black;">&#41;</span>
&nbsp;
        algo_res = bin_add<span style="color: black;">&#91;</span>bin_add.<span style="color: black;">index</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">'1'</span><span style="color: black;">&#41;</span>:<span style="color: black;">&#93;</span>
        py_res = py_add<span style="color: black;">&#91;</span>py_add.<span style="color: black;">index</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">'1'</span><span style="color: black;">&#41;</span>:<span style="color: black;">&#93;</span>
&nbsp;
        <span style="color: #008000;">self</span>.<span style="color: black;">assertEqual</span><span style="color: black;">&#40;</span>py_res, algo_res<span style="color: black;">&#41;</span>
&nbsp;
&nbsp;
&nbsp;
<span style="color: #ff7700;font-weight:bold;">if</span> <span style="color: #483d8b;">'__main__'</span> == __name__:
    <span style="color: #dc143c;">unittest</span>.<span style="color: black;">main</span><span style="color: black;">&#40;</span><span style="color: black;">&#41;</span></pre></div></div>
<h2>Binary Multiplication</h2>
<p>We are still using strings to represent bit sequences. We are still working from right to left, shifting to the left every number from the first number that needs to be multiplied by 1 in the second number. We then append the result to a list that we sum at the end, using the previous algorithm.</p>
<h3>Code:</h3>
<div class="wp_syntax"><div class="code"><pre class="python" style="font-family:monospace;"><span style="color: #483d8b;">&quot;&quot;&quot;Simple Binary multiplication algorithm&quot;&quot;&quot;</span>
&nbsp;
&nbsp;
<span style="color: #ff7700;font-weight:bold;">import</span> <span style="color: #dc143c;">sys</span>
<span style="color: #ff7700;font-weight:bold;">import</span> <span style="color: #dc143c;">os</span>.<span style="color: black;">path</span>
&nbsp;
<span style="color: #ff7700;font-weight:bold;">from</span> binary_addition <span style="color: #ff7700;font-weight:bold;">import</span> binary_addition
&nbsp;
&nbsp;
<span style="color: #ff7700;font-weight:bold;">def</span> binary_multiplication<span style="color: black;">&#40;</span>bin_a, bin_b<span style="color: black;">&#41;</span>:
    <span style="color: #483d8b;">&quot;&quot;&quot;Multiplies two binary numbers by using python lists to
    easily shift digits around&quot;&quot;&quot;</span>
&nbsp;
    temp_result = <span style="color: black;">&#91;</span><span style="color: black;">&#93;</span>
    result = <span style="color: #483d8b;">&quot;0&quot;</span>
&nbsp;
    <span style="color: #808080; font-style: italic;"># Remove any unnecessary padding</span>
    bin_a = bin_a<span style="color: black;">&#91;</span>bin_a.<span style="color: black;">index</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">'1'</span><span style="color: black;">&#41;</span>:<span style="color: black;">&#93;</span>
    bin_b = bin_b<span style="color: black;">&#91;</span>bin_b.<span style="color: black;">index</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">'1'</span><span style="color: black;">&#41;</span>:<span style="color: black;">&#93;</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">for</span> i <span style="color: #ff7700;font-weight:bold;">in</span> <span style="color: #008000;">range</span><span style="color: black;">&#40;</span><span style="color: #ff4500;">0</span>, <span style="color: #008000;">len</span><span style="color: black;">&#40;</span>bin_b<span style="color: black;">&#41;</span><span style="color: black;">&#41;</span><span style="color: black;">&#91;</span>::-<span style="color: #ff4500;">1</span><span style="color: black;">&#93;</span>:
        <span style="color: #ff7700;font-weight:bold;">if</span> bin_b<span style="color: black;">&#91;</span>i<span style="color: black;">&#93;</span> == <span style="color: #483d8b;">'1'</span>:
            temp_result.<span style="color: black;">append</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">&quot;%s%s&quot;</span> <span style="color: #66cc66;">%</span> <span style="color: black;">&#40;</span>bin_a, <span style="color: #483d8b;">&quot;0&quot;</span> <span style="color: #66cc66;">*</span> <span style="color: black;">&#40;</span><span style="color: #008000;">len</span><span style="color: black;">&#40;</span>bin_b<span style="color: black;">&#41;</span>-i-<span style="color: #ff4500;">1</span><span style="color: black;">&#41;</span><span style="color: black;">&#41;</span><span style="color: black;">&#41;</span>
        <span style="color: #ff7700;font-weight:bold;">else</span>:
            temp_result.<span style="color: black;">append</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">&quot;0&quot;</span><span style="color: black;">&#41;</span>
&nbsp;
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">for</span> val <span style="color: #ff7700;font-weight:bold;">in</span> temp_result:
        result = binary_addition<span style="color: black;">&#40;</span><span style="color: #008000;">str</span><span style="color: black;">&#40;</span>result<span style="color: black;">&#41;</span>, <span style="color: #008000;">str</span><span style="color: black;">&#40;</span>val<span style="color: black;">&#41;</span><span style="color: black;">&#41;</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">return</span> result</pre></div></div>
<h3>Unit Test:</h3>
<div class="wp_syntax"><div class="code"><pre class="python" style="font-family:monospace;"><span style="color: #483d8b;">&quot;&quot;&quot;Unit test for binary_addition.py&quot;&quot;&quot;</span>
&nbsp;
<span style="color: #ff7700;font-weight:bold;">import</span> <span style="color: #dc143c;">unittest</span>
<span style="color: #ff7700;font-weight:bold;">from</span> binary_multiplication <span style="color: #ff7700;font-weight:bold;">import</span> binary_multiplication
&nbsp;
<span style="color: #ff7700;font-weight:bold;">class</span> TestBinaryAddition<span style="color: black;">&#40;</span><span style="color: #dc143c;">unittest</span>.<span style="color: black;">TestCase</span><span style="color: black;">&#41;</span>:
&nbsp;
    <span style="color: #483d8b;">&quot;&quot;&quot;Comparing python binary multiplication against our own&quot;&quot;&quot;</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">def</span> test_add_same_length<span style="color: black;">&#40;</span><span style="color: #008000;">self</span><span style="color: black;">&#41;</span>:
&nbsp;
        <span style="color: #483d8b;">&quot;&quot;&quot;Multiplying 2 binary numbers of the same length&quot;&quot;&quot;</span>
&nbsp;
        bin_a = <span style="color: #483d8b;">'001001101'</span>
        bin_b = <span style="color: #483d8b;">'011011010'</span>
&nbsp;
        <span style="color: #008000;">self</span>._compare_multiplications<span style="color: black;">&#40;</span>bin_a, bin_b<span style="color: black;">&#41;</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">def</span> test_simple<span style="color: black;">&#40;</span><span style="color: #008000;">self</span><span style="color: black;">&#41;</span>:
&nbsp;
        <span style="color: #483d8b;">&quot;&quot;&quot;Multiplying 2 simple binary numbers&quot;&quot;&quot;</span>
        bin_a = <span style="color: #483d8b;">'110'</span>
        bin_b = <span style="color: #483d8b;">'101'</span>
&nbsp;
        <span style="color: #008000;">self</span>._compare_multiplications<span style="color: black;">&#40;</span>bin_a, bin_b<span style="color: black;">&#41;</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">def</span> test_add_b_larger<span style="color: black;">&#40;</span><span style="color: #008000;">self</span><span style="color: black;">&#41;</span>:
&nbsp;
        <span style="color: #483d8b;">&quot;&quot;&quot;B has more digits than A&quot;&quot;&quot;</span>
&nbsp;
        bin_a = <span style="color: #483d8b;">'010'</span>
        bin_b = <span style="color: #483d8b;">'111001011000101'</span>
&nbsp;
        <span style="color: #008000;">self</span>._compare_multiplications<span style="color: black;">&#40;</span>bin_a, bin_b<span style="color: black;">&#41;</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">def</span> test_add_b_smaller<span style="color: black;">&#40;</span><span style="color: #008000;">self</span><span style="color: black;">&#41;</span>:
&nbsp;
        <span style="color: #483d8b;">&quot;&quot;&quot; B has less digits than A &quot;&quot;&quot;</span>
&nbsp;
        bin_a = <span style="color: #483d8b;">'111001011000101'</span>
        bin_b = <span style="color: #483d8b;">'010'</span>
&nbsp;
        <span style="color: #008000;">self</span>._compare_multiplications<span style="color: black;">&#40;</span>bin_a, bin_b<span style="color: black;">&#41;</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">def</span> _compare_multiplications<span style="color: black;">&#40;</span><span style="color: #008000;">self</span>, bin_a, bin_b<span style="color: black;">&#41;</span>:
&nbsp;
        <span style="color: #483d8b;">&quot;&quot;&quot;Compares the python implementation against ours&quot;&quot;&quot;</span>
&nbsp;
        bin_mult = binary_multiplication<span style="color: black;">&#40;</span>bin_a, bin_b<span style="color: black;">&#41;</span>
        py_mult = bin<span style="color: black;">&#40;</span><span style="color: #008000;">eval</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">&quot;0b%s&quot;</span> <span style="color: #66cc66;">%</span> bin_a<span style="color: black;">&#41;</span> <span style="color: #66cc66;">*</span> <span style="color: #008000;">eval</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">&quot;0b%s&quot;</span> <span style="color: #66cc66;">%</span> bin_b<span style="color: black;">&#41;</span><span style="color: black;">&#41;</span>
&nbsp;
        algo_res = bin_mult<span style="color: black;">&#91;</span>bin_mult.<span style="color: black;">index</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">'1'</span><span style="color: black;">&#41;</span>:<span style="color: black;">&#93;</span>
        py_res = py_mult<span style="color: black;">&#91;</span>py_mult.<span style="color: black;">index</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">'1'</span><span style="color: black;">&#41;</span>:<span style="color: black;">&#93;</span>
&nbsp;
        <span style="color: #008000;">self</span>.<span style="color: black;">assertEqual</span><span style="color: black;">&#40;</span>py_res, algo_res<span style="color: black;">&#41;</span>
&nbsp;
&nbsp;
&nbsp;
<span style="color: #ff7700;font-weight:bold;">if</span> <span style="color: #483d8b;">'__main__'</span> == __name__:
    <span style="color: #dc143c;">unittest</span>.<span style="color: black;">main</span><span style="color: black;">&#40;</span><span style="color: black;">&#41;</span></pre></div></div>
<p><a href="http://www.addtoany.com/add_to/reddit?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F17%2Falgorithms-in-python-binary-operations%2F&amp;linkname=Algorithms%20in%20Python%3A%20Binary%20Operations" title="Reddit" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/reddit.png" width="16" height="16" alt="Reddit"/></a> <a href="http://www.addtoany.com/add_to/delicious?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F17%2Falgorithms-in-python-binary-operations%2F&amp;linkname=Algorithms%20in%20Python%3A%20Binary%20Operations" title="Delicious" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/delicious.png" width="16" height="16" alt="Delicious"/></a> <a href="http://www.addtoany.com/add_to/google_bookmarks?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F17%2Falgorithms-in-python-binary-operations%2F&amp;linkname=Algorithms%20in%20Python%3A%20Binary%20Operations" title="Google Bookmarks" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/google.png" width="16" height="16" alt="Google Bookmarks"/></a> <a href="http://www.addtoany.com/add_to/facebook?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F17%2Falgorithms-in-python-binary-operations%2F&amp;linkname=Algorithms%20in%20Python%3A%20Binary%20Operations" title="Facebook" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/facebook.png" width="16" height="16" alt="Facebook"/></a> <a href="http://www.addtoany.com/add_to/google_buzz?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F17%2Falgorithms-in-python-binary-operations%2F&amp;linkname=Algorithms%20in%20Python%3A%20Binary%20Operations" title="Google Buzz" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/google_buzz.png" width="16" height="16" alt="Google Buzz"/></a> <a href="http://www.addtoany.com/add_to/stumbleupon?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F17%2Falgorithms-in-python-binary-operations%2F&amp;linkname=Algorithms%20in%20Python%3A%20Binary%20Operations" title="StumbleUpon" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/stumbleupon.png" width="16" height="16" alt="StumbleUpon"/></a> <a href="http://www.addtoany.com/add_to/linkedin?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F17%2Falgorithms-in-python-binary-operations%2F&amp;linkname=Algorithms%20in%20Python%3A%20Binary%20Operations" title="LinkedIn" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/linkedin.png" width="16" height="16" alt="LinkedIn"/></a> <a href="http://www.addtoany.com/add_to/twitter?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F17%2Falgorithms-in-python-binary-operations%2F&amp;linkname=Algorithms%20in%20Python%3A%20Binary%20Operations" title="Twitter" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/twitter.png" width="16" height="16" alt="Twitter"/></a> <a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save">Share</a> </p>
<p>Related posts:<ol><li><a href='http://blog.madpython.com/2010/07/10/algorithms-in-python-base-expansion/' rel='bookmark' title='Permanent Link: Algorithms in Python: Base Expansion'>Algorithms in Python: Base Expansion</a></li>
<li><a href='http://blog.madpython.com/2009/03/07/extending-postgresql-with-python/' rel='bookmark' title='Permanent Link: Extending PostgreSQL with Python'>Extending PostgreSQL with Python</a></li>
</ol></p>]]></content:encoded>
			<wfw:commentRss>http://blog.madpython.com/2010/07/17/algorithms-in-python-binary-operations/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Algorithms in Python: Base Expansion</title>
		<link>http://blog.madpython.com/2010/07/10/algorithms-in-python-base-expansion/</link>
		<comments>http://blog.madpython.com/2010/07/10/algorithms-in-python-base-expansion/#comments</comments>
		<pubDate>Sun, 11 Jul 2010 00:53:49 +0000</pubDate>
		<dc:creator>Xavier</dc:creator>
				<category><![CDATA[Programming]]></category>
		<category><![CDATA[tech]]></category>
		<category><![CDATA[algorithms]]></category>
		<category><![CDATA[CS]]></category>
		<category><![CDATA[programming]]></category>
		<category><![CDATA[python]]></category>
		<guid isPermaLink="false">http://blog.madpython.com/?p=111</guid>
		<description><![CDATA[I felt it would be helpful to folks interested in Python and studying algorithms, to review some commonly studied algorithms in Computer Science by providing a small description and a Python implementation of each algorithm. This week, we&#8217;ll cover an &#8230; <a href="http://blog.madpython.com/2010/07/10/algorithms-in-python-base-expansion/">Continue reading <span class="meta-nav">&#8594;</span></a>
Related posts:<ol><li><a href='http://blog.madpython.com/2010/07/17/algorithms-in-python-binary-operations/' rel='bookmark' title='Permanent Link: Algorithms in Python: Binary Operations'>Algorithms in Python: Binary Operations</a></li>
</ol>]]></description>
			<content:encoded><![CDATA[<p>I felt it would be helpful to folks interested in Python and studying algorithms, to review some commonly studied algorithms in Computer Science by providing a small description and a Python implementation of each algorithm.</p>
<p>This week, we&#8217;ll cover an introductory algorithm for converting from one numeral base to another. Here is the python code:</p>
<div class="wp_syntax"><div class="code"><pre class="python" style="font-family:monospace;"><span style="color: #483d8b;">&quot;&quot;&quot;Simple implementation of a base expansion algorithm&quot;&quot;&quot;</span>
&nbsp;
<span style="color: #ff7700;font-weight:bold;">import</span> <span style="color: #dc143c;">math</span>
&nbsp;
<span style="color: #ff7700;font-weight:bold;">def</span> base_expand<span style="color: black;">&#40;</span>base, val<span style="color: black;">&#41;</span>:
    <span style="color: #483d8b;">&quot;&quot;&quot;This simple function performs a base-expansion from decimal
    using moduli and a translation table. The translation table is
    a clear limitation here, in that it implies the maximum base
    is 36.&quot;&quot;&quot;</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">if</span> <span style="color: black;">&#40;</span>base <span style="color: #66cc66;">&lt;</span> <span style="color: #ff4500;">2</span><span style="color: black;">&#41;</span> <span style="color: #ff7700;font-weight:bold;">or</span> <span style="color: black;">&#40;</span>base <span style="color: #66cc66;">&gt;</span> <span style="color: #ff4500;">36</span><span style="color: black;">&#41;</span>:
        <span style="color: #ff7700;font-weight:bold;">raise</span> BaseOutOfBoundsError<span style="color: black;">&#40;</span>base<span style="color: black;">&#41;</span>
&nbsp;
    trans_table = <span style="color: #483d8b;">'0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'</span>
    res = <span style="color: #483d8b;">''</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">while</span> val <span style="color: #66cc66;">!</span>= <span style="color: #ff4500;">0</span>:
        res += trans_table<span style="color: black;">&#91;</span><span style="color: black;">&#40;</span><span style="color: #008000;">int</span><span style="color: black;">&#40;</span>val <span style="color: #66cc66;">%</span> base<span style="color: black;">&#41;</span><span style="color: black;">&#41;</span><span style="color: black;">&#93;</span>
        val = <span style="color: #dc143c;">math</span>.<span style="color: black;">floor</span><span style="color: black;">&#40;</span>val / base<span style="color: black;">&#41;</span>
    <span style="color: #ff7700;font-weight:bold;">return</span> res<span style="color: black;">&#91;</span>::-<span style="color: #ff4500;">1</span><span style="color: black;">&#93;</span>
&nbsp;
<span style="color: #ff7700;font-weight:bold;">class</span> BaseOutOfBoundsError<span style="color: black;">&#40;</span><span style="color: #008000;">Exception</span><span style="color: black;">&#41;</span>:
    <span style="color: #483d8b;">&quot;&quot;&quot;Base must be between 2 and 36&quot;&quot;&quot;</span>
    <span style="color: #ff7700;font-weight:bold;">def</span> <span style="color: #0000cd;">__init__</span><span style="color: black;">&#40;</span><span style="color: #008000;">self</span>, val<span style="color: black;">&#41;</span>:
        <span style="color: #008000;">self</span>.<span style="color: black;">val</span> = val
    <span style="color: #ff7700;font-weight:bold;">def</span> <span style="color: #0000cd;">__str__</span><span style="color: black;">&#40;</span><span style="color: #008000;">self</span><span style="color: black;">&#41;</span>:
        <span style="color: #ff7700;font-weight:bold;">print</span> <span style="color: #483d8b;">&quot;<span style="color: #000099; font-weight: bold;">\n</span>Invalid base: %s. Base must be (x | x &gt; 1; x &lt; 37)&quot;</span> <span style="color: #66cc66;">%</span> \
            <span style="color: #008000;">self</span>.<span style="color: black;">val</span></pre></div></div>
<p>Here is a unit-test for base_expand.py:</p>
<div class="wp_syntax"><div class="code"><pre class="python" style="font-family:monospace;"><span style="color: #483d8b;">&quot;&quot;&quot;Unit tests for base_expansion.py&quot;&quot;&quot;</span>
&nbsp;
<span style="color: #ff7700;font-weight:bold;">import</span> <span style="color: #dc143c;">unittest</span>
<span style="color: #ff7700;font-weight:bold;">from</span> base_expansion <span style="color: #ff7700;font-weight:bold;">import</span> base_expand, BaseOutOfBoundsError
&nbsp;
<span style="color: #808080; font-style: italic;"># Unit tests for base_expansion.py</span>
<span style="color: #ff7700;font-weight:bold;">class</span> TestVals<span style="color: black;">&#40;</span><span style="color: #dc143c;">unittest</span>.<span style="color: black;">TestCase</span><span style="color: black;">&#41;</span>:
    <span style="color: #483d8b;">&quot;&quot;&quot;Test suite&quot;&quot;&quot;</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">def</span> test_known_values<span style="color: black;">&#40;</span><span style="color: #008000;">self</span><span style="color: black;">&#41;</span>:
        <span style="color: #483d8b;">&quot;&quot;&quot;Testing against known values&quot;&quot;&quot;</span>
&nbsp;
        vals = <span style="color: black;">&#91;</span><span style="color: black;">&#123;</span><span style="color: #483d8b;">'val'</span>: <span style="color: #ff4500;">8</span>, <span style="color: #483d8b;">'base'</span>: <span style="color: #ff4500;">2</span>, <span style="color: #483d8b;">'expect'</span>: <span style="color: #483d8b;">'1000'</span><span style="color: black;">&#125;</span>,
            <span style="color: black;">&#123;</span><span style="color: #483d8b;">'val'</span>: <span style="color: #ff4500;">915652</span>, <span style="color: #483d8b;">'base'</span>: <span style="color: #ff4500;">16</span>, <span style="color: #483d8b;">'expect'</span>: <span style="color: #483d8b;">'DF8C4'</span><span style="color: black;">&#125;</span>,
            <span style="color: black;">&#123;</span><span style="color: #483d8b;">'val'</span>: <span style="color: #ff4500;">256</span>, <span style="color: #483d8b;">'base'</span>: <span style="color: #ff4500;">10</span>, <span style="color: #483d8b;">'expect'</span>: <span style="color: #483d8b;">'256'</span><span style="color: black;">&#125;</span>,
            <span style="color: black;">&#123;</span><span style="color: #483d8b;">'val'</span>: <span style="color: #ff4500;">88189</span>, <span style="color: #483d8b;">'base'</span>: <span style="color: #ff4500;">8</span>, <span style="color: #483d8b;">'expect'</span>: <span style="color: #483d8b;">'254175'</span><span style="color: black;">&#125;</span><span style="color: black;">&#93;</span>
&nbsp;
        <span style="color: #ff7700;font-weight:bold;">for</span> val <span style="color: #ff7700;font-weight:bold;">in</span> vals:
            <span style="color: #008000;">self</span>.<span style="color: black;">assertEqual</span><span style="color: black;">&#40;</span>val<span style="color: black;">&#91;</span><span style="color: #483d8b;">'expect'</span><span style="color: black;">&#93;</span>, \
                base_expand<span style="color: black;">&#40;</span>val<span style="color: black;">&#91;</span><span style="color: #483d8b;">'base'</span><span style="color: black;">&#93;</span>, val<span style="color: black;">&#91;</span><span style="color: #483d8b;">'val'</span><span style="color: black;">&#93;</span><span style="color: black;">&#41;</span><span style="color: black;">&#41;</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">def</span> test_invalid_base<span style="color: black;">&#40;</span><span style="color: #008000;">self</span><span style="color: black;">&#41;</span>:
        <span style="color: #483d8b;">&quot;&quot;&quot; Testing invalid bases &quot;&quot;&quot;</span>
&nbsp;
        bases = <span style="color: black;">&#91;</span><span style="color: #ff4500;">1</span>, <span style="color: #ff4500;">37</span>, <span style="color: #ff4500;">50</span>, <span style="color: #ff4500;">100</span><span style="color: black;">&#93;</span>
        <span style="color: #ff7700;font-weight:bold;">for</span> base <span style="color: #ff7700;font-weight:bold;">in</span> bases:
            <span style="color: #008000;">self</span>.<span style="color: black;">assertRaises</span><span style="color: black;">&#40;</span>BaseOutOfBoundsError, base_expand, \
                base, <span style="color: #ff4500;">1</span><span style="color: black;">&#41;</span>
&nbsp;
&nbsp;
&nbsp;
<span style="color: #ff7700;font-weight:bold;">if</span> <span style="color: #483d8b;">'__main__'</span> == __name__:
    <span style="color: #dc143c;">unittest</span>.<span style="color: black;">main</span><span style="color: black;">&#40;</span><span style="color: black;">&#41;</span></pre></div></div>
<p><a href="http://www.addtoany.com/add_to/reddit?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F10%2Falgorithms-in-python-base-expansion%2F&amp;linkname=Algorithms%20in%20Python%3A%20Base%20Expansion" title="Reddit" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/reddit.png" width="16" height="16" alt="Reddit"/></a> <a href="http://www.addtoany.com/add_to/delicious?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F10%2Falgorithms-in-python-base-expansion%2F&amp;linkname=Algorithms%20in%20Python%3A%20Base%20Expansion" title="Delicious" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/delicious.png" width="16" height="16" alt="Delicious"/></a> <a href="http://www.addtoany.com/add_to/google_bookmarks?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F10%2Falgorithms-in-python-base-expansion%2F&amp;linkname=Algorithms%20in%20Python%3A%20Base%20Expansion" title="Google Bookmarks" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/google.png" width="16" height="16" alt="Google Bookmarks"/></a> <a href="http://www.addtoany.com/add_to/facebook?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F10%2Falgorithms-in-python-base-expansion%2F&amp;linkname=Algorithms%20in%20Python%3A%20Base%20Expansion" title="Facebook" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/facebook.png" width="16" height="16" alt="Facebook"/></a> <a href="http://www.addtoany.com/add_to/google_buzz?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F10%2Falgorithms-in-python-base-expansion%2F&amp;linkname=Algorithms%20in%20Python%3A%20Base%20Expansion" title="Google Buzz" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/google_buzz.png" width="16" height="16" alt="Google Buzz"/></a> <a href="http://www.addtoany.com/add_to/stumbleupon?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F10%2Falgorithms-in-python-base-expansion%2F&amp;linkname=Algorithms%20in%20Python%3A%20Base%20Expansion" title="StumbleUpon" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/stumbleupon.png" width="16" height="16" alt="StumbleUpon"/></a> <a href="http://www.addtoany.com/add_to/linkedin?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F10%2Falgorithms-in-python-base-expansion%2F&amp;linkname=Algorithms%20in%20Python%3A%20Base%20Expansion" title="LinkedIn" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/linkedin.png" width="16" height="16" alt="LinkedIn"/></a> <a href="http://www.addtoany.com/add_to/twitter?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F07%2F10%2Falgorithms-in-python-base-expansion%2F&amp;linkname=Algorithms%20in%20Python%3A%20Base%20Expansion" title="Twitter" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/twitter.png" width="16" height="16" alt="Twitter"/></a> <a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save">Share</a> </p>
<p>Related posts:<ol><li><a href='http://blog.madpython.com/2010/07/17/algorithms-in-python-binary-operations/' rel='bookmark' title='Permanent Link: Algorithms in Python: Binary Operations'>Algorithms in Python: Binary Operations</a></li>
</ol></p>]]></content:encoded>
			<wfw:commentRss>http://blog.madpython.com/2010/07/10/algorithms-in-python-base-expansion/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Django Context Processors Best Practice</title>
		<link>http://blog.madpython.com/2010/04/07/django-context-processors-best-practice/</link>
		<comments>http://blog.madpython.com/2010/04/07/django-context-processors-best-practice/#comments</comments>
		<pubDate>Thu, 08 Apr 2010 00:59:39 +0000</pubDate>
		<dc:creator>Xavier</dc:creator>
				<category><![CDATA[Django]]></category>
		<category><![CDATA[Web Development]]></category>
		<category><![CDATA[Web Frameworks]]></category>
		<category><![CDATA[tech]]></category>
		<category><![CDATA[convention]]></category>
		<category><![CDATA[python]]></category>
		<category><![CDATA[tips]]></category>
		<guid isPermaLink="false">http://blog.madpython.com/?p=61</guid>
		<description><![CDATA[In this post, i&#8217;ll show you a simple trick to ensure your Django context-processors don&#8217;t break when Django 1.2 (and possibly future releases as well) is released. If you&#8217;re not familiar with the concept of context-processors, I&#8217;ll also explain what &#8230; <a href="http://blog.madpython.com/2010/04/07/django-context-processors-best-practice/">Continue reading <span class="meta-nav">&#8594;</span></a>
Related posts:<ol><li><a href='http://blog.madpython.com/2009/03/07/extending-postgresql-with-python/' rel='bookmark' title='Permanent Link: Extending PostgreSQL with Python'>Extending PostgreSQL with Python</a></li>
</ol>]]></description>
			<content:encoded><![CDATA[<p>In this post, i&#8217;ll show you a simple trick to ensure your Django context-processors don&#8217;t break when Django 1.2 (and possibly future releases as well) is released.</p>
<p>If you&#8217;re not familiar with the concept of context-processors, I&#8217;ll also explain what those are and how they work, so don&#8217;t panic. Finally, i&#8217;ll also spend a minute explaining why I consider this to be best-practice.</p>
<h2>What are template context processors?</h2>
<p>Django&#8217;s context processors are a facility that allows you to provide data and callbacks to your templates.</p>
<p>You can do so in one of two ways:</p>
<ol>
<li><strong>On an individual request basis</strong>: by passing a custom <code>Context</code> value to your <code>render_to_response()</code> call</li>
<li><strong>Globally</strong>: by creating a <em>context processor method</em> that accepts a <code>HttpRequest</code> object as input, and returns a payload or callback, <strong>then</strong> registering the context processor in your <code>settings.py</code>, <strong>then</strong> providing your <code>render_to_response()</code> call with the built-in <code>RequestContext</code> attribute instead of your own (you can always extend <code>RequestContext</code> to add more data on an individual request basis of course).</li>
</ol>
<p>If that approach for passing data to templates sounded absurd and obfuscated to you, you&#8217;re not alone. The complexity involved in such a simple operation is unwarranted and counter-productive, but every system has its shortcomings.</p>
<h2>The Issue</h2>
<p>If you follow the <a href="http://docs.djangoproject.com/en/dev/ref/templates/api/#id1" onclick="return TrackClick('http%3A%2F%2Fdocs.djangoproject.com%2Fen%2Fdev%2Fref%2Ftemplates%2Fapi%2F%23id1','Django+documentation')">Django documentation</a> or <a href="http://djangobook.com/en/2.0/" onclick="return TrackClick('http%3A%2F%2Fdjangobook.com%2Fen%2F2.0%2F','The+Django+Book')">The Django Book</a>&#8216;s approach to configuring your own custom context-processors, you&#8217;ll notice that you are encouraged to add to your settings.py a hardcoded list of built-in context processors. If you follow that approach, your context-processors declaration will look like this:</p>
<div class="wp_syntax"><div class="code"><pre class="python" style="font-family:monospace;">TEMPLATE_CONTEXT_PROCESSORS = <span style="color: black;">&#40;</span><span style="color: #483d8b;">&quot;django.contrib.auth.context_processors.auth&quot;</span>,
<span style="color: #483d8b;">&quot;django.core.context_processors.debug&quot;</span>,
<span style="color: #483d8b;">&quot;django.core.context_processors.i18n&quot;</span>,
<span style="color: #483d8b;">&quot;django.core.context_processors.media&quot;</span>,
<span style="color: #483d8b;">&quot;django.contrib.messages.context_processors.messages&quot;</span><span style="color: black;">&#41;</span></pre></div></div>
<p>But if you pay close attention to <a href="http://docs.djangoproject.com/en/dev/ref/settings/#template-context-processors" onclick="return TrackClick('http%3A%2F%2Fdocs.djangoproject.com%2Fen%2Fdev%2Fref%2Fsettings%2F%23template-context-processors','the+development+version%22s+documentation')">the development version&#8217;s documentation</a>, you&#8217;ll notice a couple of interesting notes:</p>
<blockquote><p><strong>Changed in Django Development version: </strong>&#8220;django.contrib.messages.context_processors.messages&#8221; was added to the default. For more information, see the messages documentation.<br />
<strong>Changed in Django Development version</strong>: The auth context processor was moved in this release from its old location django.core.context_processors.auth to django.contrib.auth.context_processors.auth.</p></blockquote>
<p>This is a red flag! The Django dev team would like you to use hardcoded values that reference to classes that will no longer exist once the next version is released, and that omit new processors that you are likely to require.</p>
<h2>The Solution</h2>
<p>Obviously Django has access to its own default settings, so there must be a way to simply <em>extend</em> the defaults instead of overriding them with hardcoded values. You just need to dig around a bit in <a href="http://code.djangoproject.com/browser/django/trunk/django/conf/global_settings.py#L186" onclick="return TrackClick('http%3A%2F%2Fcode.djangoproject.com%2Fbrowser%2Fdjango%2Ftrunk%2Fdjango%2Fconf%2Fglobal_settings.py%23L186','the+Django+source+code')">the Django source code</a> to find exactly how. I&#8217;ll save you some digging:</p>
<p>Add this at the top of your settings.py file:</p>
<div class="wp_syntax"><div class="code"><pre class="python" style="font-family:monospace;"><span style="color: #ff7700;font-weight:bold;">import</span> django.<span style="color: black;">conf</span>.<span style="color: black;">global_settings</span> <span style="color: #ff7700;font-weight:bold;">as</span> DEFAULT_SETTINGS</pre></div></div>
<p>Then extend the default context processors:</p>
<div class="wp_syntax"><div class="code"><pre class="python" style="font-family:monospace;">TEMPLATE_CONTEXT_PROCESSORS = DEFAULT_SETTINGS.<span style="color: black;">TEMPLATE_CONTEXT_PROCESSORS</span> + <span style="color: black;">&#40;</span>
<span style="color: #483d8b;">&quot;myapp.context_processors.example&quot;</span>,
<span style="color: #483d8b;">&quot;myapp.context_processors.other_example&quot;</span>,
<span style="color: #808080; font-style: italic;"># etc...</span>
<span style="color: black;">&#41;</span></pre></div></div>
<h2>Why is this a best-practice approach?</h2>
<p>In software-engineering, you want to ensure maximum (reasonable) future interoperability of all your components, and there is really no component as important as your actual development framework, Django or otherwise.</p>
<p>Using hardcoded values that are already defined somewhere not only breaks <acronym title="Don't Repeat Yourself">DRY</acronym>, but it also introduces possible breakage on framework upgrades. I know you are diligent and always read the release notes before upgrading critical components, and I know you use a staging environment to test those changes, but by actively looking out for this kind of traps, you have just saved yourself some debugging time and some head-scratching.</p>
<p>Happy coding!</p>
<p><a href="http://www.addtoany.com/add_to/reddit?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F04%2F07%2Fdjango-context-processors-best-practice%2F&amp;linkname=Django%20Context%20Processors%20Best%20Practice" title="Reddit" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/reddit.png" width="16" height="16" alt="Reddit"/></a> <a href="http://www.addtoany.com/add_to/delicious?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F04%2F07%2Fdjango-context-processors-best-practice%2F&amp;linkname=Django%20Context%20Processors%20Best%20Practice" title="Delicious" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/delicious.png" width="16" height="16" alt="Delicious"/></a> <a href="http://www.addtoany.com/add_to/google_bookmarks?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F04%2F07%2Fdjango-context-processors-best-practice%2F&amp;linkname=Django%20Context%20Processors%20Best%20Practice" title="Google Bookmarks" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/google.png" width="16" height="16" alt="Google Bookmarks"/></a> <a href="http://www.addtoany.com/add_to/facebook?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F04%2F07%2Fdjango-context-processors-best-practice%2F&amp;linkname=Django%20Context%20Processors%20Best%20Practice" title="Facebook" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/facebook.png" width="16" height="16" alt="Facebook"/></a> <a href="http://www.addtoany.com/add_to/google_buzz?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F04%2F07%2Fdjango-context-processors-best-practice%2F&amp;linkname=Django%20Context%20Processors%20Best%20Practice" title="Google Buzz" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/google_buzz.png" width="16" height="16" alt="Google Buzz"/></a> <a href="http://www.addtoany.com/add_to/stumbleupon?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F04%2F07%2Fdjango-context-processors-best-practice%2F&amp;linkname=Django%20Context%20Processors%20Best%20Practice" title="StumbleUpon" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/stumbleupon.png" width="16" height="16" alt="StumbleUpon"/></a> <a href="http://www.addtoany.com/add_to/linkedin?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F04%2F07%2Fdjango-context-processors-best-practice%2F&amp;linkname=Django%20Context%20Processors%20Best%20Practice" title="LinkedIn" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/linkedin.png" width="16" height="16" alt="LinkedIn"/></a> <a href="http://www.addtoany.com/add_to/twitter?linkurl=http%3A%2F%2Fblog.madpython.com%2F2010%2F04%2F07%2Fdjango-context-processors-best-practice%2F&amp;linkname=Django%20Context%20Processors%20Best%20Practice" title="Twitter" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/twitter.png" width="16" height="16" alt="Twitter"/></a> <a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save">Share</a> </p>
<p>Related posts:<ol><li><a href='http://blog.madpython.com/2009/03/07/extending-postgresql-with-python/' rel='bookmark' title='Permanent Link: Extending PostgreSQL with Python'>Extending PostgreSQL with Python</a></li>
</ol></p>]]></content:encoded>
			<wfw:commentRss>http://blog.madpython.com/2010/04/07/django-context-processors-best-practice/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Extending PostgreSQL with Python</title>
		<link>http://blog.madpython.com/2009/03/07/extending-postgresql-with-python/</link>
		<comments>http://blog.madpython.com/2009/03/07/extending-postgresql-with-python/#comments</comments>
		<pubDate>Sat, 07 Mar 2009 22:56:31 +0000</pubDate>
		<dc:creator>Xavier</dc:creator>
				<category><![CDATA[Databases]]></category>
		<category><![CDATA[linux]]></category>
		<category><![CDATA[tech]]></category>
		<category><![CDATA[unix]]></category>
		<category><![CDATA[postgres]]></category>
		<category><![CDATA[python]]></category>
		<category><![CDATA[scripting]]></category>
		<category><![CDATA[tips]]></category>
		<guid isPermaLink="false">http://blog.madpython.com/?p=40</guid>
		<description><![CDATA[One of the features I enjoy the most about PostgreSQL is the ability to write stored procedures in C, Perl, TCL, PgSQL, and yes&#8230; obviously also in Python. I&#8217;ve been using this feature since 7.4, so any recent version of &#8230; <a href="http://blog.madpython.com/2009/03/07/extending-postgresql-with-python/">Continue reading <span class="meta-nav">&#8594;</span></a>
Related posts:<ol><li><a href='http://blog.madpython.com/2009/03/06/fixing-custom-sequences-in-postgresql/' rel='bookmark' title='Permanent Link: Fixing custom sequences in PostgreSQL'>Fixing custom sequences in PostgreSQL</a></li>
<li><a href='http://blog.madpython.com/2009/03/01/ahh-those-cool-little-cli-tools/' rel='bookmark' title='Permanent Link: Ahh those cool little CLI tools&#8230;'>Ahh those cool little CLI tools&#8230;</a></li>
<li><a href='http://blog.madpython.com/2009/03/02/apache2-shortcuts/' rel='bookmark' title='Permanent Link: Apache2 shortcuts'>Apache2 shortcuts</a></li>
</ol>]]></description>
			<content:encoded><![CDATA[<p>One of the features I enjoy the most about PostgreSQL is the ability to write stored procedures in C, Perl, TCL, PgSQL, and yes&#8230; obviously also in Python. I&#8217;ve been using this feature since 7.4, so any recent version of PostgreSQL is pretty much guaranteed to support it, but you&#8217;ll need to have the pl/python procedural language contrib module installed. Once it&#8217;s installed, you can activate it for your current database using the following query:</p>
<div class="wp_syntax"><div class="code"><pre class="sql" style="font-family:monospace;"><span style="color: #993333; font-weight: bold;">CREATE</span> <span style="color: #993333; font-weight: bold;">PROCEDURAL</span> <span style="color: #993333; font-weight: bold;">LANGUAGE</span> plpythonu;</pre></div></div>
<p>Once the language bindings have been activated, you can start writing your stored procedures in python, however you should really read up on the following subjects first:</p>
<ul>
<li><a href="http://www.postgresql.org/docs/8.3/interactive/sql-createfunction.html" onclick="return TrackClick('http%3A%2F%2Fwww.postgresql.org%2Fdocs%2F8.3%2Finteractive%2Fsql-createfunction.html','CREATE+FUNCTION+statement+syntax')" target="_blank">CREATE FUNCTION statement syntax</a></li>
<li><a href="http://www.postgresql.org/docs/8.3/interactive/plpython-funcs.html" onclick="return TrackClick('http%3A%2F%2Fwww.postgresql.org%2Fdocs%2F8.3%2Finteractive%2Fplpython-funcs.html','PL%2FPython+Implementation+Documentation')" target="_blank">PL/Python Implementation Documentation</a></li>
</ul>
<p>As an example, I&#8217;ve written a little <acronym title="Stored Procedure">SP</acronym> in PL/Python to provide support for <acronym title="Perl-Compatible Regular Expressions">PCRE</acronym> since the stock distribution of PostgreSQL only supports LIKE/SIMILAR, and POSIX Style Regular Expressions.</p>
<p>Let&#8217;s create our Python language binding, and create a standard text storage table:</p>
<div class="wp_syntax"><div class="code"><pre class="sql" style="font-family:monospace;"><span style="color: #808080; font-style: italic;">-- Activate PL/Python</span>
<span style="color: #993333; font-weight: bold;">CREATE</span> <span style="color: #993333; font-weight: bold;">PROCEDURAL</span> <span style="color: #993333; font-weight: bold;">LANGUAGE</span> plpythonu;
&nbsp;
<span style="color: #808080; font-style: italic;">-- Create a plain text-storage table</span>
<span style="color: #993333; font-weight: bold;">CREATE</span> <span style="color: #993333; font-weight: bold;">TABLE</span> text_storage
<span style="color: #66cc66;">&#40;</span>
  id serial <span style="color: #993333; font-weight: bold;">NOT</span> <span style="color: #993333; font-weight: bold;">NULL</span><span style="color: #66cc66;">,</span>
  payload character varying<span style="color: #66cc66;">&#40;</span><span style="color: #cc66cc;">128</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">,</span>
  CONSTRAINT text_storage_pkey <span style="color: #993333; font-weight: bold;">PRIMARY</span> <span style="color: #993333; font-weight: bold;">KEY</span> <span style="color: #66cc66;">&#40;</span>id<span style="color: #66cc66;">&#41;</span>
<span style="color: #66cc66;">&#41;</span>
<span style="color: #993333; font-weight: bold;">WITH</span> <span style="color: #66cc66;">&#40;</span>OIDS<span style="color: #66cc66;">=</span>FALSE<span style="color: #66cc66;">&#41;</span>;
<span style="color: #993333; font-weight: bold;">ALTER</span> <span style="color: #993333; font-weight: bold;">TABLE</span> text_storage OWNER <span style="color: #993333; font-weight: bold;">TO</span> xavier;
&nbsp;
<span style="color: #808080; font-style: italic;">-- Let's throw in an index on the payload field for good measure</span>
<span style="color: #993333; font-weight: bold;">CREATE</span> <span style="color: #993333; font-weight: bold;">INDEX</span> txt_payload_idx
  <span style="color: #993333; font-weight: bold;">ON</span> text_storage
  <span style="color: #993333; font-weight: bold;">USING</span> btree
  <span style="color: #66cc66;">&#40;</span>payload<span style="color: #66cc66;">&#41;</span>;</pre></div></div>
<p>Let&#8217;s now populate our table with some junk data:</p>
<div class="wp_syntax"><div class="code"><pre class="sql" style="font-family:monospace;"><span style="color: #993333; font-weight: bold;">INSERT</span> <span style="color: #993333; font-weight: bold;">INTO</span> text_storage <span style="color: #66cc66;">&#40;</span>payload<span style="color: #66cc66;">&#41;</span> <span style="color: #993333; font-weight: bold;">VALUES</span> <span style="color: #66cc66;">&#40;</span><span style="color: #ff0000;">'hello, world'</span><span style="color: #66cc66;">&#41;</span>;
<span style="color: #993333; font-weight: bold;">INSERT</span> <span style="color: #993333; font-weight: bold;">INTO</span> text_storage <span style="color: #66cc66;">&#40;</span>payload<span style="color: #66cc66;">&#41;</span> <span style="color: #993333; font-weight: bold;">VALUES</span> <span style="color: #66cc66;">&#40;</span><span style="color: #ff0000;">'the quick brown fox, blah blah blah'</span><span style="color: #66cc66;">&#41;</span>;
<span style="color: #993333; font-weight: bold;">INSERT</span> <span style="color: #993333; font-weight: bold;">INTO</span> text_storage <span style="color: #66cc66;">&#40;</span>payload<span style="color: #66cc66;">&#41;</span> <span style="color: #993333; font-weight: bold;">VALUES</span> <span style="color: #66cc66;">&#40;</span><span style="color: #ff0000;">'PCREs in Postgres'</span><span style="color: #66cc66;">&#41;</span>;
<span style="color: #993333; font-weight: bold;">INSERT</span> <span style="color: #993333; font-weight: bold;">INTO</span> text_storage <span style="color: #66cc66;">&#40;</span>payload<span style="color: #66cc66;">&#41;</span> <span style="color: #993333; font-weight: bold;">VALUES</span> <span style="color: #66cc66;">&#40;</span><span style="color: #ff0000;">'All hail Python!'</span><span style="color: #66cc66;">&#41;</span>;
<span style="color: #993333; font-weight: bold;">INSERT</span> <span style="color: #993333; font-weight: bold;">INTO</span> text_storage <span style="color: #66cc66;">&#40;</span>payload<span style="color: #66cc66;">&#41;</span> <span style="color: #993333; font-weight: bold;">VALUES</span> <span style="color: #66cc66;">&#40;</span><span style="color: #ff0000;">'Hello, test data!'</span><span style="color: #66cc66;">&#41;</span>;
<span style="color: #993333; font-weight: bold;">INSERT</span> <span style="color: #993333; font-weight: bold;">INTO</span> text_storage <span style="color: #66cc66;">&#40;</span>payload<span style="color: #66cc66;">&#41;</span> <span style="color: #993333; font-weight: bold;">VALUES</span> <span style="color: #66cc66;">&#40;</span><span style="color: #ff0000;">'Python would like to say Hello!'</span><span style="color: #66cc66;">&#41;</span>;</pre></div></div>
<p>And now we can go ahead and create our Python SP itself:</p>
<div class="wp_syntax"><div class="code"><pre class="plsql" style="font-family:monospace;"><span style="color: #00F;">CREATE</span> <span style="color: #00F;">OR</span> <span style="color: #000;">REPLACE</span> <span style="color: #00F;">FUNCTION</span> pcre<span style="color: #00F;">&#40;</span>text<span style="color: #00F;">,</span> text<span style="color: #00F;">&#41;</span>
  RETURNS <span style="color: #00F;">INTEGER</span> <span style="color: #00F;">AS</span>
$BODY$import re
&nbsp;
regex  <span style="color: #00F;">=</span> args<span style="color: #00F;">&#91;</span><span style="color: #800;">0</span><span style="color: #00F;">&#93;</span>
in_str <span style="color: #00F;">=</span> args<span style="color: #00F;">&#91;</span><span style="color: #800;">1</span><span style="color: #00F;">&#93;</span>
&nbsp;
compiled <span style="color: #00F;">=</span> re<span style="color: #00F;">.</span>compile<span style="color: #00F;">&#40;</span>regex<span style="color: #00F;">&#41;</span>
&nbsp;
<span style="color: #00F;">IF</span> compiled<span style="color: #00F;">.</span>search<span style="color: #00F;">&#40;</span>in_str<span style="color: #00F;">&#41;</span><span style="color: #00F;">:</span>
	<span style="color: #00F;">RETURN</span> <span style="color: #800;">1</span>
<span style="color: #00F;">ELSE</span><span style="color: #00F;">:</span>
	<span style="color: #00F;">RETURN</span> <span style="color: #800;">0</span>$BODY$
  LANGUAGE <span style="color: #F00;">'plpythonu'</span> VOLATILE
  COST <span style="color: #800;">100</span><span style="color: #00F;">;</span></pre></div></div>
<p>As you can see, our PCRE matching system is extremely simple, yet pretty powerful. We import Python&#8217;s built-in <strong>re</strong> module, compile the specified regex argument, then attempt to match it against the other argument. Here&#8217;s a usage example on our test table:</p>
<div class="wp_syntax"><div class="code"><pre class="sql" style="font-family:monospace;"><span style="color: #993333; font-weight: bold;">SELECT</span> id<span style="color: #66cc66;">,</span> payload <span style="color: #993333; font-weight: bold;">FROM</span> text_storage <span style="color: #993333; font-weight: bold;">WHERE</span> pcre<span style="color: #66cc66;">&#40;</span><span style="color: #ff0000;">'[H|h]ello'</span><span style="color: #66cc66;">,</span> payload<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">=</span> <span style="color: #cc66cc;">1</span>;
 id <span style="color: #66cc66;">|</span>             payload
<span style="color: #808080; font-style: italic;">----+---------------------------------</span>
  <span style="color: #cc66cc;">1</span> <span style="color: #66cc66;">|</span> hello<span style="color: #66cc66;">,</span> world
  <span style="color: #cc66cc;">5</span> <span style="color: #66cc66;">|</span> Hello<span style="color: #66cc66;">,</span> test <span style="color: #993333; font-weight: bold;">DATA</span>!
  <span style="color: #cc66cc;">6</span> <span style="color: #66cc66;">|</span> Python would <span style="color: #993333; font-weight: bold;">LIKE</span> <span style="color: #993333; font-weight: bold;">TO</span> say Hello!
<span style="color: #66cc66;">&#40;</span><span style="color: #cc66cc;">3</span> rows<span style="color: #66cc66;">&#41;</span></pre></div></div>
<p>As always, feel free to suggest any improvements.</p>
<p><a href="http://www.addtoany.com/add_to/reddit?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F07%2Fextending-postgresql-with-python%2F&amp;linkname=Extending%20PostgreSQL%20with%20Python" title="Reddit" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/reddit.png" width="16" height="16" alt="Reddit"/></a> <a href="http://www.addtoany.com/add_to/delicious?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F07%2Fextending-postgresql-with-python%2F&amp;linkname=Extending%20PostgreSQL%20with%20Python" title="Delicious" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/delicious.png" width="16" height="16" alt="Delicious"/></a> <a href="http://www.addtoany.com/add_to/google_bookmarks?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F07%2Fextending-postgresql-with-python%2F&amp;linkname=Extending%20PostgreSQL%20with%20Python" title="Google Bookmarks" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/google.png" width="16" height="16" alt="Google Bookmarks"/></a> <a href="http://www.addtoany.com/add_to/facebook?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F07%2Fextending-postgresql-with-python%2F&amp;linkname=Extending%20PostgreSQL%20with%20Python" title="Facebook" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/facebook.png" width="16" height="16" alt="Facebook"/></a> <a href="http://www.addtoany.com/add_to/google_buzz?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F07%2Fextending-postgresql-with-python%2F&amp;linkname=Extending%20PostgreSQL%20with%20Python" title="Google Buzz" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/google_buzz.png" width="16" height="16" alt="Google Buzz"/></a> <a href="http://www.addtoany.com/add_to/stumbleupon?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F07%2Fextending-postgresql-with-python%2F&amp;linkname=Extending%20PostgreSQL%20with%20Python" title="StumbleUpon" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/stumbleupon.png" width="16" height="16" alt="StumbleUpon"/></a> <a href="http://www.addtoany.com/add_to/linkedin?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F07%2Fextending-postgresql-with-python%2F&amp;linkname=Extending%20PostgreSQL%20with%20Python" title="LinkedIn" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/linkedin.png" width="16" height="16" alt="LinkedIn"/></a> <a href="http://www.addtoany.com/add_to/twitter?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F07%2Fextending-postgresql-with-python%2F&amp;linkname=Extending%20PostgreSQL%20with%20Python" title="Twitter" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/twitter.png" width="16" height="16" alt="Twitter"/></a> <a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save">Share</a> </p>
<p>Related posts:<ol><li><a href='http://blog.madpython.com/2009/03/06/fixing-custom-sequences-in-postgresql/' rel='bookmark' title='Permanent Link: Fixing custom sequences in PostgreSQL'>Fixing custom sequences in PostgreSQL</a></li>
<li><a href='http://blog.madpython.com/2009/03/01/ahh-those-cool-little-cli-tools/' rel='bookmark' title='Permanent Link: Ahh those cool little CLI tools&#8230;'>Ahh those cool little CLI tools&#8230;</a></li>
<li><a href='http://blog.madpython.com/2009/03/02/apache2-shortcuts/' rel='bookmark' title='Permanent Link: Apache2 shortcuts'>Apache2 shortcuts</a></li>
</ol></p>]]></content:encoded>
			<wfw:commentRss>http://blog.madpython.com/2009/03/07/extending-postgresql-with-python/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Fixing custom sequences in PostgreSQL</title>
		<link>http://blog.madpython.com/2009/03/06/fixing-custom-sequences-in-postgresql/</link>
		<comments>http://blog.madpython.com/2009/03/06/fixing-custom-sequences-in-postgresql/#comments</comments>
		<pubDate>Sat, 07 Mar 2009 00:52:47 +0000</pubDate>
		<dc:creator>Xavier</dc:creator>
				<category><![CDATA[Databases]]></category>
		<category><![CDATA[linux]]></category>
		<category><![CDATA[tech]]></category>
		<category><![CDATA[unix]]></category>
		<category><![CDATA[postgres]]></category>
		<category><![CDATA[python]]></category>
		<category><![CDATA[scripting]]></category>
		<category><![CDATA[tips]]></category>
		<guid isPermaLink="false">http://blog.madpython.com/?p=35</guid>
		<description><![CDATA[PostgreSQL provides a mechanism called sequences, which I believe is extracted from ANSI-SQL92, though I&#8217;m too lazy to check, which are basically stateful counters that provide some helper functions. The primary use of sequences in PostgreSQL and Oracle, is to &#8230; <a href="http://blog.madpython.com/2009/03/06/fixing-custom-sequences-in-postgresql/">Continue reading <span class="meta-nav">&#8594;</span></a>
Related posts:<ol><li><a href='http://blog.madpython.com/2009/03/07/extending-postgresql-with-python/' rel='bookmark' title='Permanent Link: Extending PostgreSQL with Python'>Extending PostgreSQL with Python</a></li>
<li><a href='http://blog.madpython.com/2009/03/02/apache2-shortcuts/' rel='bookmark' title='Permanent Link: Apache2 shortcuts'>Apache2 shortcuts</a></li>
</ol>]]></description>
			<content:encoded><![CDATA[<p>PostgreSQL provides a mechanism called sequences, which I believe is extracted from ANSI-SQL92, though I&#8217;m too lazy to check, which are basically stateful counters that provide some helper functions. The primary use of sequences in PostgreSQL and Oracle, is to implement auto-incrementing counters as a table field.</p>
<p>PostgreSQL will automatically create a sequence when you use the &#8220;SERIAL&#8221; datatype for your field, and will take care of assigning the default value of your field as the result of the nextval() call on the sequence, so most of the time you don&#8217;t need to interact directly with sequences.</p>
<p>Where things can get hairy however, is when you back up your data using pg_dump or any other mechanism, and restore that data in a table that is already populated. A common scenario for example, is populating a table that already has some recent data, with some older data you&#8217;ve been storing in archival. The opposite is true if you are trying to archive data from a table to a backup database for example.</p>
<p>Whenever you manually have to provide a value for the field assigned to a sequence, you are pretty much guaranteed to break the sequence unless you take the time to nextval() your sequence until it is in sync. This is a real problem, as pg_dump does not include sequence synchronization in its output.</p>
<p>The quickest way to synchronize a sequence, based on my observations, is to run the following query, taking care to replace the name of the sequence [SEQ] and the name of the associated table [TABLE] and field [FIELD]:</p>
<div class="wp_syntax"><div class="code"><pre class="sql" style="font-family:monospace;"><span style="color: #993333; font-weight: bold;">SELECT</span> <span style="color: #993333; font-weight: bold;">SETVAL</span><span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#91;</span>SEQ<span style="color: #66cc66;">&#93;</span><span style="color: #66cc66;">,</span> COALESCE<span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span><span style="color: #993333; font-weight: bold;">SELECT</span> <span style="color: #66cc66;">&#91;</span><span style="color: #993333; font-weight: bold;">FIELD</span><span style="color: #66cc66;">&#93;</span> <span style="color: #993333; font-weight: bold;">FROM</span> <span style="color: #66cc66;">&#91;</span><span style="color: #993333; font-weight: bold;">TABLE</span><span style="color: #66cc66;">&#93;</span> <span style="color: #993333; font-weight: bold;">ORDER</span> <span style="color: #993333; font-weight: bold;">BY</span> <span style="color: #66cc66;">&#91;</span><span style="color: #993333; font-weight: bold;">FIELD</span><span style="color: #66cc66;">&#93;</span> <span style="color: #993333; font-weight: bold;">DESC</span> <span style="color: #993333; font-weight: bold;">LIMIT</span> <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">,</span> <span style="color: #cc66cc;">0</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">+</span><span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span></pre></div></div>
<p>This will fetch the highest value of [FIELD] in [TABLE], increment it by 1, and synchronize the sequence [SEQ] to the new value.</p>
<p>I&#8217;ve also written the following little Python script that will look for any <strong><em>non-system</em></strong> sequence in the specified database, and use this method to repair it. Let me know if it works out for you, or if you&#8217;d like to suggest some improvements.</p>
<p><strong>Requirements</strong>: Python 2.5+, PsycoPG2 Python module (python-psycopg2)</p>
<div class="wp_syntax"><div class="code"><pre class="python" style="font-family:monospace;"><span style="color: #808080; font-style: italic;">#!/usr/bin/env python</span>
<span style="color: #808080; font-style: italic;"># -*- coding: utf-8 -*-</span>
&nbsp;
&nbsp;
<span style="color: #808080; font-style: italic;"># Standard imports</span>
<span style="color: #ff7700;font-weight:bold;">import</span> <span style="color: #dc143c;">sys</span>
<span style="color: #ff7700;font-weight:bold;">import</span> <span style="color: #dc143c;">os</span>
<span style="color: #ff7700;font-weight:bold;">import</span> <span style="color: #dc143c;">time</span>
<span style="color: #ff7700;font-weight:bold;">from</span> <span style="color: #dc143c;">optparse</span> <span style="color: #ff7700;font-weight:bold;">import</span> OptionParser
&nbsp;
<span style="color: #808080; font-style: italic;"># psycopg2 import</span>
<span style="color: #ff7700;font-weight:bold;">try</span>:
    <span style="color: #ff7700;font-weight:bold;">import</span> psycopg2
<span style="color: #ff7700;font-weight:bold;">except</span> <span style="color: #008000;">ImportError</span>, e:
    <span style="color: #ff7700;font-weight:bold;">print</span> <span style="color: #483d8b;">'You must install the python module named &quot;psycopg2&quot; in order to use this module.'</span>
    <span style="color: #dc143c;">sys</span>.<span style="color: black;">exit</span><span style="color: black;">&#40;</span><span style="color: #dc143c;">os</span>.<span style="color: black;">EX_SOFTWARE</span><span style="color: black;">&#41;</span>
&nbsp;
&nbsp;
&nbsp;
<span style="color: #ff7700;font-weight:bold;">class</span> PgRepairman:
    <span style="color: #ff7700;font-weight:bold;">def</span> <span style="color: #0000cd;">__init__</span><span style="color: black;">&#40;</span><span style="color: #008000;">self</span>, options, <span style="color: #dc143c;">parser</span><span style="color: black;">&#41;</span>:
        <span style="color: #008000;">self</span>.<span style="color: black;">options</span> = options
        <span style="color: #ff7700;font-weight:bold;">try</span>:
            dsn = <span style="color: #483d8b;">&quot;dbname=%s host=%s user=%s&quot;</span> <span style="color: #66cc66;">%</span> <span style="color: black;">&#40;</span>options.<span style="color: black;">db</span>, options.<span style="color: black;">host</span>, options.<span style="color: #dc143c;">user</span><span style="color: black;">&#41;</span>
            dsn += <span style="color: black;">&#40;</span><span style="color: #483d8b;">&quot;&quot;</span> <span style="color: #66cc66;">!</span>= options.<span style="color: black;">passwd</span><span style="color: black;">&#41;</span> <span style="color: #ff7700;font-weight:bold;">and</span> <span style="color: black;">&#40;</span><span style="color: #483d8b;">&quot;password=%s&quot;</span> <span style="color: #66cc66;">%</span> options.<span style="color: black;">password</span><span style="color: black;">&#41;</span> <span style="color: #ff7700;font-weight:bold;">or</span> <span style="color: #483d8b;">&quot;&quot;</span>
            <span style="color: #008000;">self</span>.<span style="color: black;">conn</span> = psycopg2.<span style="color: black;">connect</span><span style="color: black;">&#40;</span>dsn<span style="color: black;">&#41;</span>
            <span style="color: #008000;">self</span>.<span style="color: black;">curs</span> = <span style="color: #008000;">self</span>.<span style="color: black;">conn</span>.<span style="color: black;">cursor</span><span style="color: black;">&#40;</span><span style="color: black;">&#41;</span>
        <span style="color: #ff7700;font-weight:bold;">except</span> <span style="color: #008000;">Exception</span>, e:
            <span style="color: #ff7700;font-weight:bold;">print</span> <span style="color: #483d8b;">&quot;ERROR - %s&quot;</span> <span style="color: #66cc66;">%</span> e
            <span style="color: #dc143c;">sys</span>.<span style="color: black;">exit</span><span style="color: black;">&#40;</span><span style="color: #ff4500;">1</span><span style="color: black;">&#41;</span>
&nbsp;
&nbsp;
    <span style="color: #808080; font-style: italic;"># Returns a dict for a psycopg2 row object</span>
    <span style="color: #ff7700;font-weight:bold;">def</span> _to_dict<span style="color: black;">&#40;</span><span style="color: #008000;">self</span>, desc, res<span style="color: black;">&#41;</span>:
        <span style="color: #ff7700;font-weight:bold;">return</span> <span style="color: #008000;">dict</span><span style="color: black;">&#40;</span><span style="color: #008000;">zip</span><span style="color: black;">&#40;</span><span style="color: black;">&#91;</span>x<span style="color: black;">&#91;</span><span style="color: #ff4500;">0</span><span style="color: black;">&#93;</span> <span style="color: #ff7700;font-weight:bold;">for</span> x <span style="color: #ff7700;font-weight:bold;">in</span> desc<span style="color: black;">&#93;</span>, res<span style="color: black;">&#41;</span><span style="color: black;">&#41;</span>
&nbsp;
&nbsp;
    <span style="color: #808080; font-style: italic;"># Attempt to locate all custom sequences</span>
    <span style="color: #ff7700;font-weight:bold;">def</span> findSequences<span style="color: black;">&#40;</span><span style="color: #008000;">self</span><span style="color: black;">&#41;</span>:
        seq_query = <span style="color: #483d8b;">&quot;&quot;&quot;
        SELECT pc1.relname AS seq, pc2.relname AS table, c.attname AS field
        FROM pg_depend, pg_class pc1, pg_class pc2, pg_attribute c
        WHERE pc1.oid = pg_depend.objid
            AND pc2.oid = pg_depend.refobjid
            AND c.attnum = pg_depend.refobjsubid
            AND c.attrelid = pc2.oid
            AND pc1.relkind = 'S'
            AND pc1.relname NOT LIKE 'pg_toast%%'
        &quot;&quot;&quot;</span>
&nbsp;
        <span style="color: #ff7700;font-weight:bold;">try</span>:
            <span style="color: #008000;">self</span>.<span style="color: black;">print_verbose</span><span style="color: black;">&#40;</span>seq_query<span style="color: black;">&#41;</span>
            <span style="color: #008000;">self</span>.<span style="color: black;">curs</span>.<span style="color: black;">execute</span><span style="color: black;">&#40;</span>seq_query<span style="color: black;">&#41;</span>
        <span style="color: #ff7700;font-weight:bold;">except</span> <span style="color: #008000;">Exception</span>, e:
            <span style="color: #ff7700;font-weight:bold;">print</span> <span style="color: #483d8b;">&quot;[ERROR] - %s&quot;</span> <span style="color: #66cc66;">%</span> e
            <span style="color: #dc143c;">sys</span>.<span style="color: black;">exit</span><span style="color: black;">&#40;</span><span style="color: #ff4500;">1</span><span style="color: black;">&#41;</span>
&nbsp;
        desc = <span style="color: #008000;">self</span>.<span style="color: black;">curs</span>.<span style="color: black;">description</span>
        <span style="color: #ff7700;font-weight:bold;">for</span> row <span style="color: #ff7700;font-weight:bold;">in</span> <span style="color: #008000;">self</span>.<span style="color: black;">curs</span>.<span style="color: black;">fetchall</span><span style="color: black;">&#40;</span><span style="color: black;">&#41;</span>:
            <span style="color: #ff7700;font-weight:bold;">yield</span> <span style="color: #008000;">self</span>._to_dict<span style="color: black;">&#40;</span>desc, row<span style="color: black;">&#41;</span>
&nbsp;
&nbsp;
    <span style="color: #808080; font-style: italic;"># Increment the key value to the value of the sequence + 1</span>
    <span style="color: #ff7700;font-weight:bold;">def</span> fixSequences<span style="color: black;">&#40;</span><span style="color: #008000;">self</span><span style="color: black;">&#41;</span>:
        <span style="color: #ff7700;font-weight:bold;">for</span> seq <span style="color: #ff7700;font-weight:bold;">in</span> <span style="color: #008000;">self</span>.<span style="color: black;">findSequences</span><span style="color: black;">&#40;</span><span style="color: black;">&#41;</span>:
            <span style="color: #ff7700;font-weight:bold;">print</span> <span style="color: #483d8b;">&quot;Fixing sequence %s in table %s&quot;</span> <span style="color: #66cc66;">%</span> <span style="color: black;">&#40;</span>seq<span style="color: black;">&#91;</span><span style="color: #483d8b;">'seq'</span><span style="color: black;">&#93;</span>, seq<span style="color: black;">&#91;</span><span style="color: #483d8b;">'table'</span><span style="color: black;">&#93;</span><span style="color: black;">&#41;</span>
            fix_query = <span style="color: #483d8b;">&quot;SELECT setval('%s', COALESCE((SELECT %s FROM %s ORDER BY %s DESC LIMIT 1), 0)+1)&quot;</span> <span style="color: #66cc66;">%</span> <span style="color: black;">&#40;</span>seq<span style="color: black;">&#91;</span><span style="color: #483d8b;">'seq'</span><span style="color: black;">&#93;</span>, seq<span style="color: black;">&#91;</span><span style="color: #483d8b;">'field'</span><span style="color: black;">&#93;</span>, seq<span style="color: black;">&#91;</span><span style="color: #483d8b;">'table'</span><span style="color: black;">&#93;</span>, seq<span style="color: black;">&#91;</span><span style="color: #483d8b;">'field'</span><span style="color: black;">&#93;</span><span style="color: black;">&#41;</span>
            <span style="color: #ff7700;font-weight:bold;">try</span>:
                <span style="color: #008000;">self</span>.<span style="color: black;">print_verbose</span><span style="color: black;">&#40;</span>fix_query<span style="color: black;">&#41;</span>
                <span style="color: #008000;">self</span>.<span style="color: black;">curs</span>.<span style="color: black;">execute</span><span style="color: black;">&#40;</span>fix_query<span style="color: black;">&#41;</span>
            <span style="color: #ff7700;font-weight:bold;">except</span> <span style="color: #008000;">Exception</span>, e:
                <span style="color: #ff7700;font-weight:bold;">print</span> <span style="color: #483d8b;">&quot;[WARNING] - %s&quot;</span> <span style="color: #66cc66;">%</span> e
                <span style="color: #ff7700;font-weight:bold;">pass</span>
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">def</span> print_verbose<span style="color: black;">&#40;</span><span style="color: #008000;">self</span>, msg<span style="color: black;">&#41;</span>:
        <span style="color: #ff7700;font-weight:bold;">if</span> <span style="color: black;">&#40;</span><span style="color: #008000;">True</span> == <span style="color: #008000;">self</span>.<span style="color: black;">options</span>.<span style="color: black;">verbose</span><span style="color: black;">&#41;</span>:
            <span style="color: #ff7700;font-weight:bold;">print</span> <span style="color: #483d8b;">&quot;[DEBUG] - %s&quot;</span> <span style="color: #66cc66;">%</span> msg
&nbsp;
<span style="color: #ff7700;font-weight:bold;">if</span> __name__==<span style="color: #483d8b;">'__main__'</span>:
    usage       = <span style="color: #483d8b;">&quot;Usage: %prog &lt;options&gt; [-v --verbose] [-u --username | -p --password <span style="color: #000099; font-weight: bold;">\ </span>-o --host | -d --database]&quot;</span>
    version     = <span style="color: #483d8b;">&quot;%prog v1.0<span style="color: #000099; font-weight: bold;">\n</span>Distributed under the LGPL2 License&quot;</span>
    description = <span style="color: #483d8b;">&quot;Increments all sequences in a PostgreSQL database&quot;</span>
    <span style="color: #dc143c;">parser</span> = OptionParser<span style="color: black;">&#40;</span>usage=usage, version=version, description=description<span style="color: black;">&#41;</span>
    <span style="color: #dc143c;">parser</span>.<span style="color: black;">add_option</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">&quot;-v&quot;</span>, <span style="color: #483d8b;">&quot;--verbose&quot;</span>, action=<span style="color: #483d8b;">&quot;store_true&quot;</span>, dest=<span style="color: #483d8b;">&quot;verbose&quot;</span>, default=<span style="color: #008000;">False</span>, <span style="color: #008000;">help</span>=<span style="color: #483d8b;">&quot;Enable extra output&quot;</span><span style="color: black;">&#41;</span>
    <span style="color: #dc143c;">parser</span>.<span style="color: black;">add_option</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">&quot;-o&quot;</span>, <span style="color: #483d8b;">&quot;--host&quot;</span>, action=<span style="color: #483d8b;">&quot;store&quot;</span>, dest=<span style="color: #483d8b;">&quot;host&quot;</span>, default=<span style="color: #483d8b;">&quot;127.0.0.1&quot;</span>, <span style="color: #008000;">help</span>=<span style="color: #483d8b;">&quot;Database hostname/IP&quot;</span><span style="color: black;">&#41;</span>
    <span style="color: #dc143c;">parser</span>.<span style="color: black;">add_option</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">&quot;-u&quot;</span>, <span style="color: #483d8b;">&quot;--username&quot;</span>, action=<span style="color: #483d8b;">&quot;store&quot;</span>, dest=<span style="color: #483d8b;">&quot;user&quot;</span>, default=<span style="color: #483d8b;">&quot;postgres&quot;</span>, <span style="color: #008000;">help</span>=<span style="color: #483d8b;">&quot;Database Username&quot;</span><span style="color: black;">&#41;</span>
    <span style="color: #dc143c;">parser</span>.<span style="color: black;">add_option</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">&quot;-p&quot;</span>, <span style="color: #483d8b;">&quot;--password&quot;</span>, action=<span style="color: #483d8b;">&quot;store&quot;</span>, dest=<span style="color: #483d8b;">&quot;passwd&quot;</span>, default=<span style="color: #483d8b;">&quot;&quot;</span>, <span style="color: #008000;">help</span>=<span style="color: #483d8b;">&quot;Database Password&quot;</span><span style="color: black;">&#41;</span>
    <span style="color: #dc143c;">parser</span>.<span style="color: black;">add_option</span><span style="color: black;">&#40;</span><span style="color: #483d8b;">&quot;-d&quot;</span>, <span style="color: #483d8b;">&quot;--database&quot;</span>, action=<span style="color: #483d8b;">&quot;store&quot;</span>, dest=<span style="color: #483d8b;">&quot;db&quot;</span>, default=<span style="color: #483d8b;">&quot;template1&quot;</span>, <span style="color: #008000;">help</span>=<span style="color: #483d8b;">&quot;Database Name&quot;</span><span style="color: black;">&#41;</span>
&nbsp;
&nbsp;
    <span style="color: #ff7700;font-weight:bold;">try</span>:
        <span style="color: black;">&#40;</span>options, args<span style="color: black;">&#41;</span> = <span style="color: #dc143c;">parser</span>.<span style="color: black;">parse_args</span><span style="color: black;">&#40;</span><span style="color: black;">&#41;</span>
        obj = PgRepairman<span style="color: black;">&#40;</span>options, <span style="color: #dc143c;">parser</span><span style="color: black;">&#41;</span>
        obj.<span style="color: black;">fixSequences</span><span style="color: black;">&#40;</span><span style="color: black;">&#41;</span>
    <span style="color: #ff7700;font-weight:bold;">except</span> <span style="color: #008000;">KeyboardInterrupt</span>, e:
        <span style="color: #dc143c;">sys</span>.<span style="color: black;">exit</span><span style="color: black;">&#40;</span><span style="color: #ff4500;">1</span><span style="color: black;">&#41;</span></pre></div></div>
<p>You can also download the script <a href="http://blog.madpython.com/wp-content/uploads/2009/03/pg_sequences.py" onclick="return TrackClick('http%3A%2F%2Fblog.madpython.com%2Fwp-content%2Fuploads%2F2009%2F03%2Fpg_sequences.py','here')">here</a>.</p>
<p><a href="http://www.addtoany.com/add_to/reddit?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F06%2Ffixing-custom-sequences-in-postgresql%2F&amp;linkname=Fixing%20custom%20sequences%20in%20PostgreSQL" title="Reddit" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/reddit.png" width="16" height="16" alt="Reddit"/></a> <a href="http://www.addtoany.com/add_to/delicious?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F06%2Ffixing-custom-sequences-in-postgresql%2F&amp;linkname=Fixing%20custom%20sequences%20in%20PostgreSQL" title="Delicious" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/delicious.png" width="16" height="16" alt="Delicious"/></a> <a href="http://www.addtoany.com/add_to/google_bookmarks?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F06%2Ffixing-custom-sequences-in-postgresql%2F&amp;linkname=Fixing%20custom%20sequences%20in%20PostgreSQL" title="Google Bookmarks" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/google.png" width="16" height="16" alt="Google Bookmarks"/></a> <a href="http://www.addtoany.com/add_to/facebook?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F06%2Ffixing-custom-sequences-in-postgresql%2F&amp;linkname=Fixing%20custom%20sequences%20in%20PostgreSQL" title="Facebook" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/facebook.png" width="16" height="16" alt="Facebook"/></a> <a href="http://www.addtoany.com/add_to/google_buzz?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F06%2Ffixing-custom-sequences-in-postgresql%2F&amp;linkname=Fixing%20custom%20sequences%20in%20PostgreSQL" title="Google Buzz" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/google_buzz.png" width="16" height="16" alt="Google Buzz"/></a> <a href="http://www.addtoany.com/add_to/stumbleupon?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F06%2Ffixing-custom-sequences-in-postgresql%2F&amp;linkname=Fixing%20custom%20sequences%20in%20PostgreSQL" title="StumbleUpon" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/stumbleupon.png" width="16" height="16" alt="StumbleUpon"/></a> <a href="http://www.addtoany.com/add_to/linkedin?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F06%2Ffixing-custom-sequences-in-postgresql%2F&amp;linkname=Fixing%20custom%20sequences%20in%20PostgreSQL" title="LinkedIn" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/linkedin.png" width="16" height="16" alt="LinkedIn"/></a> <a href="http://www.addtoany.com/add_to/twitter?linkurl=http%3A%2F%2Fblog.madpython.com%2F2009%2F03%2F06%2Ffixing-custom-sequences-in-postgresql%2F&amp;linkname=Fixing%20custom%20sequences%20in%20PostgreSQL" title="Twitter" rel="nofollow" target="_blank"><img src="http://blog.madpython.com/wp-content/plugins/add-to-any/icons/twitter.png" width="16" height="16" alt="Twitter"/></a> <a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save">Share</a> </p>
<p>Related posts:<ol><li><a href='http://blog.madpython.com/2009/03/07/extending-postgresql-with-python/' rel='bookmark' title='Permanent Link: Extending PostgreSQL with Python'>Extending PostgreSQL with Python</a></li>
<li><a href='http://blog.madpython.com/2009/03/02/apache2-shortcuts/' rel='bookmark' title='Permanent Link: Apache2 shortcuts'>Apache2 shortcuts</a></li>
</ol></p>]]></content:encoded>
			<wfw:commentRss>http://blog.madpython.com/2009/03/06/fixing-custom-sequences-in-postgresql/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
