cPickle

cPickleを使ってみる。

ダンプするとき

import cPickle

with open("list.txt","w") as f:
    cPickle.dump([1,2,3,4,5],f)

ロードするとき

with open("list.txt","r") as f:
    a = cPickle.load(f)

print a

ProductName Python クックブック 第2版
Alex Martelli,Anna Martelli Ravenscroft,David Ascher
オライリー・ジャパン / ¥ 4,410 ()
在庫あり。

Flaskでコードをハイライトするサービス

pythonのMarkdownにはPygmentsをつかったコードハイライト用のエクステンションがあるので、それを使えば簡単にかける

flaskmd

スクリーンショット撮ってから「セッションとか使ってないからsessionとかkeyとかいらないじゃん」と思って少し綺麗にしたので最終的には15行くらい。

flaskmd.py

from flask import Flask, request, url_for, render_template
from markdown import markdown

DEBUG = True
app = Flask(__name__)
app.config.from_object(__name__)

@app.route('/',methods=['POST', 'GET'])
def show_code(code = ""):
    if request.method == 'POST':
        code = markdown(request.form['code'], ['codehilite'],safe_mode=False)
    return render_template('show_code.html', code=code)

if __name__ == '__main__':
    app.run()

show_code.html

markdownで生成したhtmlをそのままテンプレートに渡すとエスケープされてしまうので、autoescapeをFalseにした。今回ここが一番悩んだがドキュメントをちゃんと読めば書いてあった。

<!doctype html>
<title>CodeHilite</title>
<link rel=stylesheet type=text/css href="{{ url_for('static', filename='style.css') }}">
<body>
<form action="{{ url_for('show_code') }}" method=post class=add-entry>
<dl>
<dt>code:
<dd><textarea name=code rows=5 cols=40></textarea>
<dd><input type=submit value=hilite>
</dl>
</form>
<div class=page>
  <h1>CodeHilite</h1>
{% autoescape false %}
{{ code }}
{% endautoescape %}
</div>
</body>
</html>

style.css

cssはpygmentsであらかじめファイルに出力しておいた

from pygments.formatters import HtmlFormatter
with open("style.css","a") as f:
    f.write(HtmlFormatter().get_style_defs('.codehilitetable'))

Flask楽しい。

ProductName Lonely Planet Discover Japan
Chris Rowthorn,Andrew Bender,Matthew D. Firestone,Timothy N. Hornyak
Lonely Planet / ¥ 2,326 ()
在庫あり。

Haskell読書会に参加

先週末はHaskell読書会に参加してきた。みなさんお疲れ様でした。今回8章

ProductName プログラミングHaskell
Graham Hutton
オーム社 / ¥ 2,940 ()
在庫あり。

do記法使わないで書いてあったので当日は、 筆者のページのサンプル見ながらdo記法で書いてた。

この日からガンダムの公開で、ヒトも多かった。

1280177376

メロンパン

1280177381

懇親会の赤から。焼肉した後に鍋が出てきた。

1280177378 1280177383

来月は浜松。浜松は行ったことないので楽しみ。

Flaskでtwitter名刺みたいなやつをつくるやつ

OAuth使えば簡単だろうと。

twitter_card

あとは名刺型にhtmlをいじればよいんだけど飽きた。

twittercard.py

from flask import Flask, request, session, g, redirect, url_for, abort, render_template, flash
from flaskext.oauth import OAuth
import qrencode

DEBUG      = True
SECRET_KEY = 'development key'
TWITTER_URL = "http://twitter.com/"

app = Flask(__name__)
app.config.from_object(__name__)

oauth = OAuth()
twitter = oauth.remote_app('twitter',
                           base_url='http://api.twitter.com/1/',
                           request_token_url='http://api.twitter.com/oauth/request_token',
                           access_token_url='http://api.twitter.com/oauth/access_token',
                           authorize_url='http://api.twitter.com/oauth/authorize',
                           consumer_key='XXXXXXXXXXXXX',
                           consumer_secret='XXXXXXXXXXXXX'
)

@twitter.tokengetter
def get_twitter_token():
    return session.get('twitter_token')

@app.route('/')
def show_entries():
    screen_name = session.get('screen_name',None)
    name = session.get('name',None)
    profile_image_url = session.get('profile_image_url',None)
    entry = {}
    if screen_name != None: 
        imgurl = "http://twitter.com/%s" % screen_name
        imgfile   = "%s.png" % screen_name
        qrencode.encode_scaled(imgurl,50)[2].save("static/"+imgfile)
        resp = twitter.get('http://twitter.com/status/user_timeline/'+screen_name+".json")
        if resp.status == 200:
            user = resp.data[0]['user']
            name = user['name']
            url = user['url']
            profile_image_url = user['profile_image_url']
        else:
            name = None
            profile_image_url = None

        entry = dict(screen_name=screen_name,qrimg=imgfile,name=name, profile_image_url=profile_image_url, url=url)
    return render_template('show_entries.html', entry=entry)

@app.route('/login')
def login():
    return twitter.authorize(callback=url_for("oauth_authorized"))

@app.route('/logout')
def logout():
    session.pop('screen_name', None)
    session.pop('logged_in', None)
    session.pop('twitter_token', None)
    flash('You were logged out')
    return redirect(url_for('show_entries'))

@app.route('/oauth-authorized')
@twitter.authorized_handler
def oauth_authorized(resp):
    next_url = url_for('show_entries')
    if resp is None:
        flash(u'You denied the request to sign in.')
        return redirect(next_url)

    session['logged_in'] = True
    session['screen_name'] = resp['screen_name']
    session['twitter_token'] = (
        resp['oauth_token'],
        resp['oauth_token_secret']
        )

    flash(resp['screen_name'] + ' were signed in')
    return redirect(next_url)

if __name__ == '__main__':
    app.run()

テンプレート(やる気レス)

<!doctype html>
<title>TwitterCard</title>
<link rel=stylesheet type=text/css href="{{ url_for('static', filename='style.css') }}">
<div class=page>
  <h1>TwitterCard</h1>
  <div class=metanav>
    {% if not session.logged_in %}
    <a href="{{ url_for('login') }}">log in</a>
    {% else %}
    <a href="{{ url_for('logout') }}">log out</a>
    {% endif %}
  </div>
  {% for message in get_flashed_messages() %}
  <div class=flash>{{ message }}</div>
  {% endfor %}
  <img src="{{ entry.profile_image_url }}" />
  <ul class=entry>
    <li>{{ entry.screen_name }}</li>
    <li>{{ entry.name }}</li>
    <li>{{ entry.url }}</li>
  </ul>
  <img src={{ url_for('static',filename=entry.qrimg) }} />
</div>

ついったー名刺ってのがあってQRコードはblogとかのURLなんだけど、ツイッターオフとかいくと、簡単にフォローしたいからQRコードはtwitterアカウントのほうがいいかな?なんて思っていたので作ってみようとした(がもう寝る時間なので眠くなってしまい、ヤル気が急速に失われた)。


エントリ書いてて思ったんだが、ツイッターオフ参加者のIDのリストをQRコードにしといて、そいつを食わすとまとめてフォローするサービスのほうがいいような気がしてきた。そんなのないかな。

名刺見ながらポチポチ登録作業すんのもめんどいよね。

自転車のパンク修理

なぜか人生初めてのパンク修理。

ダイソーのパンク修理セットを使ってみた。

六角レンチがなくて空気入れる部分が外せなかったので、慌ててダイソーに行って買ってきた。ついでに大きさもいくつか揃えた。

1280033185

部品は無くさないようにコカコーラゼロのキャップに。本体を飲みながら作業。

1280033173

のりを塗ってパッチを張って、最後にフィルムを剥がそうとしたら端っこがちょっとめくれた。

1280033179

今日の畑(100725)

韓国唐辛子が次々と赤くなってきた。紫蘇も去年のこぼれ種からあちこちに生えているのでたまに葉っぱを収穫。

1280032166 1280032173

おくらには青虫が付き始めたので見つけ次第潰していく。そうしないと葉っぱがなくなる。

1280032179

トマトはそろそろ終了だけど、次に何植えようか。

ProductName NHK 趣味の園芸 やさいの時間 2010年 08月号 [雑誌]

日本放送出版協会 / ¥ 650 (2010-07-21)
在庫あり。

千代の光のもち米純米

綺麗さはあまり感じられなかった。ぬる燗にしてみたけど、いまいち酸が感じられなくて。 まぁ食事するときには邪魔しない感じなのでOKなんだけど、去年のひやおろしの感動は超えられなかった。

1279888453

飲み飽きはしないので、どんどん飲めてやめどきがわからないのが困ったが。

「一瞬で伝える「わかりやすさ」の技術」を読んだ

後ろに行くにしたがってタイトルからずれていくような、、、

ProductName 一瞬で伝える「わかりやすさ」の技術
齋藤 孝
大和書房 / ¥ 1,470 ()
通常1~4週間以内に発送

エッセイ集的にはありかもしれないが、結局なにを主張したいのかわからなかった。 少なくともこの本では「一瞬で伝える「わかりやすさ」の技術」は使われてない気がする。

FlaskrのモデルをSQLAlchemyで

FlaskのTutorialのモデル部分をSQLAlchemyにしてみた(Declarative)。

database.py

from sqlalchemy import create_engine
from sqlalchemy.orm import scoped_session, sessionmaker
from sqlalchemy.ext.declarative import declarative_base

engine = create_engine('sqlite:////Users/kzfm/flask/flaskr/flaskr.db', convert_unicode=True)
db_session = scoped_session(sessionmaker(autocommit=False,
                                         autoflush=False,
                                         bind=engine))
Base = declarative_base()
Base.query = db_session.query_property()

def init_db():
    Base.metadata.create_all(bind=engine)

models.py

from sqlalchemy import Column, Integer, String, Text
from database import Base

class Entry(Base):
    __tablename__ = 'entries'
    id = Column(Integer, primary_key=True)
    title = Column(String(500), unique=True)
    text = Column(Text(), unique=True)

    def __init__(self, title=None, text=None):
        self.title = title
        self.text = text

    def __repr__(self):
        return '<Title %r>' % (self.title)

これで、まだSQLiteのデータベースができてない場合にはpythonのシェルから

>>> from database import init.db
>>> from models import Entry
>>> init_db()

でデータベースが出来上がる。あとはflaskr部分。login,logoutはチュートリアルと一緒なので省略

import sqlite3
from flask import Flask, request, session, g, redirect, url_for, abort, render_template, flash
from contextlib import closing
from database import db_session
from models import Entry

DATABASE   = '/Users/kzfm/flask/flaskr/flaskr.db'
DEBUG      = True
SECRET_KEY = 'development key'
USERNAME   = 'admin'
PASSWORD   = 'default'

app = Flask(__name__)
app.config.from_object(__name__)

@app.after_request
def after_request(response):
    db_session.remove()
    return response

@app.route('/')
def show_entries():
    entries = Entry.query.all()
    return render_template('show_entries.html', entries=entries)

@app.route('/add', methods=['POST'])
def add_entry():
    if not session.get('logged_in'):
        abort(401)
    entry = Entry(request.form['title'], request.form['text'])
    db_session.add(entry)
    db_session.commit()
    return redirect(url_for('show_entries'))

簡単だ。

参考

ProductName Essential Sqlalchemy
Rick Copeland
Oreilly & Associates Inc / ¥ 3,370 ()
通常1~3週間以内に発送

「デザインイノベーション デザイン戦略の次の一手」を読んだ

沖縄行き帰りの飛行機で読んだ。

ProductName デザインイノベーション デザイン戦略の次の一手
ハルトムット・エスリンガー
翔泳社 / ¥ 2,310 ()
在庫あり。

ビジネス戦略も含めてデザイン。自分のいる業界だと創薬プロジェクトとか研究開発のマネジメントすべてを含めてデザインとして考えるようなものか。内容は幅広い。

  • 企業が成功するためには、ライバル企業に勝つだけでなく、将来、どういう競争が生まれるかを予想し、それに備えることが必要だ。
  • イノベーションのもたらす恩恵の「改善と証明」
    • プロジェクトの問題点と魅力
    • 問題の解決策
    • このイノベーションが既存のビジネスモデルに及ぼす影響
    • 会社の持っている人材と技術
    • マーケティングと販売の計画
    • 競合相手とリスク
    • 会社の強みと弱点
    • 財務予測と各段階ごとのマイルストーン
    • 立ち上げの現状と日程
    • 事業概要と要望

8番目と9番目が重要