今川館

都内勤務の地味OLです

Goの日付フォーマットの謎

Goの日付フォーマットは年が「2006」、月が「01」、日が「02」。%Y-%m-%dじゃないし「2016-12-31」もダメ。

Goのファイル・ファイルライクオブジェクトもろもろ

PythonのStringIOはGoでbytes.NewReader、などなど

Goのtype宣言はすごい

Goのtype宣言は関数にも利用できてPythonのデコレータみたいなことをやりたい場合に役に立つことを学んだ。

SQL ServerのIDENTITY値

基本事項 IDENTITY値にはSEED(初期値), INCR(増分)という概念がある。 また、IDENT_????という関数が用意されている(以下) IDENT_CURRENT 現在値 IDENT_SEED 初期値 IDENT_INCR 増分 CREATE TABLE foo ( [ID] INT IDENTITY(25, 2) PRIMARY KEY, [NAME] NVARC…

requestsを使ってInsecurePlatformWarningが出てしまうときの対処

requestsを使っていたらいつの間にかInsecurePlatformWarningという警告が出るようになってしまった。 /home/echizen/pecan/local/lib/python2.7/site-packages/requests/packages/urllib3/util/ssl_.py:90: InsecurePlatformWarning: A true SSLContext obj…

django-pyodbcでselect_for_updateは機能しないので要注意 (2015/4時点)

django-pyodbcはselect_for_updateメソッドを呼び出しても普通のSELECT文を発行する Django1.4以上でモデルマネージャやクエリセットにselect_for_updateというメソッドが使えるけれども、django-pyodbc(=SQLServer)だとこれが使えないので注意が必要。

Pythonのdate, datetimeをisinstanceで調べるとき

Pythonのdatetimeをisinstanceで調べると、date, datetimeの両方にTrueを返すので注意。 >>> from datetime import date, datetime >>> today, now = date.today(), datetime.now() >>> isinstance(today, date) True >>> isinstance(today, datetime) False…

忙しくて余裕が無くなった自分に宛てて

程度の低い人に流されないように 程度の低い人に腹を立てぬこと

SQLServerでランキングを求めるとき -- OVERの使い方(OLAP関数)

「最後に買ったもの」を調べる SQLで「誰が・何を・いつ買った」という買い物データから「その人が最後に買ったもの」を調べようとすると案外難しい。データイメージ PERSON GOODS PURCHASE_DATE +-------+-------+-------------- Tom Orange 2015-2-19 Tom …

SQLServerの文字列と日付の暗黙的型変換

文字列型からDATE/DATETIME型への暗黙的型変換 SQLServerは文字列型の値をDATEやDATETIMEで評価する必要がある場合は暗黙的に型変換を試みる。クエリ1 SELECT MAX(foo) foo FROM ( SELECT '2015-2-13' foo UNION ALL SELECT '2015-2-14' foo UNION ALL SELEC…

JSHintの設定ファイル

JSHintはデフォルトだと全然チェックしない JSLintが鬱陶しいからJSHintを使っている人は多いと思う。 ところが、JSHintはデフォルトだとチェック基準がすごく甘くてチェックとして機能しない。

setup.pyのdependency_linksの書き方

前回の続き 前回の記事でpipコマンドにGithubのリポジトリにsshで接続するURLを指定する方法を紹介した。今度はsetup.pyで非公開プロジェクトを依存パッケージに指定する方法をここにメモしておく。なお、わたしはwheelパッケージの仕様を知らないのでここで…

pipでGithubにssh接続して非公開リポジトリをインストールする

非公開リポジトリのパッケージをインストールするのは難しい 自社のプライベートプロジェクトを別のプロジェクトから利用したい場合、簡単にpipやeasy_installでインストールできず困ることがある。

AnsibleのHost Variablesの使いどころ

Host Variables とは? Inventory — Ansible Documentation [atlanta] host1 http_port=80 maxRequestsPerChild=808 host2 http_port=303 maxRequestsPerChild=909Host Variablesは上記引用の通り、インベントリのホストのセクションに併記する値なのだが、…

Ansibleのハンドラが起動するのはタスクがchangedを返したときだけ

Ansibleのハンドラとは Ansibleのタスクには `notify` という属性を追加してコールバック処理を呼ぶよう設定できる。[roles/nginx/tasks/main.yml] - name: nginx config ensure template: src=my.nginx.conf.j2 dest=/etc/nginx/conf.d/your.conf sudo: yes…

カツヒコまとめ

カツヒコとは? まきやの貴公子。スティッカムの有名人。ゆーきゅーぶのぺーぎはこちら。 https://www.youtube.com/user/katuhikodesuyo/videos?view=0&live_view=500&flow=grid&sort=dd 本名「松崎勝彦」 住所 あらかわくまきや にのぎゅうろくのはき こー…

レガシに負けるな

ニホンのサムライ・デザイナ、ニンジャ・プログラマ、アシガル・コーダから西洋のホーリー・クルセーダーまで、すべてのアヴェンジャー達にこの言葉を捧げる。「レガシに負けるな」 レガシとは何か? レガシとは悪である。 レガシは人間の心の優しさや弱さに…

Djangoのtransaction配下のモジュールはデコレータでありコンテキストマネージャであった!

Djangoでトランザクション制御するときに使うデコレータ Djangoでトランザクション制御するときは、django.db.transaction配下にある commit_on_success commit_manually こういうデコレータを使います。 from django.db import transaction @transaction.co…

Djangoのフォームに入力した値を隠しパラメータで引き継ぐ

確認画面作るのって面倒くさいですよね? 何かのデータの登録画面を作るときに入力画面→確認画面→完了画面 という遷移にすることが多いですよね。 この、「確認画面」てやつは作るの手間がかかって嫌ですよね。 複雑なデータ登録だとセッションとかキャッシ…

何段にも深くなるループを絶対に一段で書く方法

ループの中でループを回す処理は読みにくい 例えば友達が5人いて、サンドイッチが3種類あって、2種類の飲み物を配る処理を作るとします。 こういう場合、for文を何段にもネストするプログラムを書かざるを得ないときがありますよね。 for friend in friends:…

coverage combineコマンドで複数の集計結果を結合する

カバレッジ(網羅率)とは? カバレッジとはテストコードがどれだけテスト対象の内容を網羅しているかを表す割合です。例えば、以下のファイルにはfoo, bar, bazという3つの関数が定義されていますが、これらのすべての内容をテストで実行済みであればカバレッ…

イテレータは前に突き進む

http://d.hatena.ne.jp/imagawa_yakata/20120104/1325703433 このネタなのですが、id:yanolabさんが別の解答を書かれています。map_between をやってみる -slice使ったっていいじゃない編- - yanolabの日記 from itertools import islice, imap imap(func, i…

イテレータって何?

iter関数にリストを渡すとリストはコピーされないの? 昨日書いた↓この記事を見たtell-kがコメントをつけてくれました。 http://d.hatena.ne.jp/imagawa_yakata/20120104/1325703433 > itr = iter(lst)これってイテレータオブジェクトになったコピーが返って…

リストの隣接要素を次々に処理する

map_between をやってみる - Study08.net 対シンバシ殲滅用人型機動兵器 こういう記事があって、リストの隣接する要素を次々に処理する高階関数を作る話のようです。期待する挙動としては、こんな感じです。 >>> map_between(lambda x, y: x + y, [1, 2, 3, …

かけ算演算子の挙動を定義する -- Pythonの特殊メソッド

かけ算に順番が必要?必要ではない? かけ算に順番が必要である・必要ではない という話が世間では話題になっているようです。かけ算の5×3と3×5って違うの? - Togetterまとめ そういえば掛け算にはそんなルールがあったなTwitterのタイムラインでも上記の話…

re.subにはcallableなオブジェクトを渡せる

python-mini-hackathonで教えてもらった。 知らなかった。以下、例を殴り書き。 import re def main(): text = """ name = %NAME% age = %AGE% location = %LOCATION% """ pattern = r"%([A-Z]+)%" values = { "NAME" : "easy", "AGE" : "13", } def fn(matc…

python-dateutilの使い方

pythonの日付処理モジュールとしてdatetimeパッケージがあるが、dateutilパッケージのモジュールがもっと色々面倒を見てくれるのでちょっと調べてみた。 dateutilがやってくれること 沢山あるけど以下、わたしが使いたいと思った機能を抜粋。 月末を算出して…

grepに-rオプションがあることを今日知った

今までずっとfindとxargsを使っていた 今まで、特定のディレクトリを再帰的に辿って指定したパターンにマッチする文字列を含むファイルを探すときはfindとxargsを使っていた。例えば、カレントディレクトリ以下を辿って"Linux"という文字列を含むファイルを…

enumerateの代わりにitertoolsを使ってみる

itertoolsのについてメモ -- 似非言語オタクの戯言 http://d.hatena.ne.jp/aitahoge/20110517/1305611498この記事を読んでいて気づいたこと。 count(start=0, step=1) 名前のとおり、next()が呼び出される度にカウントされる。 izip()との併用とか、enumerat…

テストデータ作成のヒント: 「タプル記法」のすすめ

テストデータをどうやって作りますか? テストコードを書くとき、テストデータを投入することが多いと思うが、普段皆さんはどうやってテストデータを作っているのだろう。例えばDjangoは所定のモデルのデータをjsonやxml形式で出力して利用するfixtureという…