21
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

【AppSheet】会社の技術書を管理するアプリを作ってみた

Last updated at Posted at 2023-12-11

はじめに

お疲れ様です!Wanoで情シスをやってますgibomです!
この記事は Wano Group Advent Calendar 2023 の11日目の記事です。今回はタイトルにある通りAppSheetの記事です。これからAppSheetを使ってみようと考えている方の参考になればと思います。

背景

弊社にはエンジニア向けの技術書やマーケティング、法務関連など、スキルアップに必要な技術書があります。最近では技術書の輪読会を開いてるようです。

しかし、「あの本どこにある?誰が借りてる?」「前に似たような本を買った気がする…」「ダブって買ってしまった…」などのトラブルが発生します。
また、Qiita内の古い記事はアラートが表示されるように、古い技術書は最新のセキュリティ情報や脆弱性の対策が反映されていないことが多々あるので注意が必要です。古い技術書は早々に廃棄し新しく技術書を買いたいですが、全てチェックするのは大変です。

書籍管理をスプレッドシートやNotionで作るのも良いと思いますが、今回はAppSheetでやってみます。理由は無料で使えるから!

AppSheetとは

Google Cloudが提供するサービスの一つです。ほぼノーコードでアプリケーションを作ることができます。MicrosoftのPower Apps、サイボウズのKintoneみたいなサービスです。

以前までは最上位プランでのみ利用ができましたが、2023年7月に弊社で利用しているプランでもAppSheetが使えるようになりました。

物は試しです。手始めにAppSheetを使って、書籍管理アプリを作ってみましょう。今回は以下3点の機能が動けば成功とします。
・社内の技術書検索
・技術書の詳細情報の閲覧
・技術書の貸出管理

作成方法

今回は大まかな流れを説明します。詳しい操作方法はAppSheetのヘルプページをチェックしてください。

スプレッドシートを作成

まずはじめにデータベースを用意します。AppSheet用のデータベースを使用することも可能ですが初心者にはハードルが高いため、スプレッドシートを使うことにします。
まず、書籍一覧のスプレッドシートを作成します。かならず1行目はカラム名を記入する必要があります。

image.png

カラム名が変わるとAppSheetが動かなくなったり、カラム設定が初期化されてしまいます。誤ってカラム名を修正しないように、1行目を保護しておきましょう。

AppSheetを新規作成

次にAppSheetでアプリを作成します。
サンプルアプリを使用して作成することもできますが、さきほど作成したスプレッドシートと連携したいので、新規作成します。

AppSheetのページから
Create → App → Start with existing data を選択します。
image.png

アプリ名を決めたあと、さきほど作成したスプレッドシートを選択します。

data一覧.png

数秒後、データベースが出来上がります。

image.png

アプリケーションのプレビューも見れます。もう8割ほど完成したと思って良いでしょう。

image.png

ただ、プレビューを見るとISBNがNボタンYボタンになってます。
各カラム設定のTypeを変更して整えます。最終的にこのような形になりました。

image.png

管理番号はISBNにしようと思いましたが、同じ本が数冊あった場合の管理ができないなと思い、ISBNのあとにスプレッドシートの行番号を入れることにしました。

管理番号のカラム設定を開き、Auto Compute → App formulaにCONCATENATE([ISBN],"-",([_RowNumber] + 1000)) を入力しておきます。これでISBNが入力されると同時に管理番号が作成されます。

image.png

アプリからISBNを入力する際は手入力も可能ですが、バーコードリーダー機能をONにすることでスマホのカメラを使ってバーコードを読み取ることができます。

書籍情報の自動化

GASが利用できるので書籍検索API「Google Books API」を使い、本のバーコード(ISBNコード)から書籍情報を呼び出してスプレッドシートに入力することにしました。

設定方法はコチラを参考に作成しました。

完成

貸出履歴が残るようAutomationの設定を行い、社内の技術書のバーコードを読み取ってデータを登録します。
はい、完成です。

image.png

貸出状況を選択すると、従業員一覧がドロップダウンリストで表示されます。本を借りたい方は貸出状況から選択します。(わざわざ自分の名前を探して登録するのは手間ではありますが、読んだ本をすぐ誰かに渡せるよう自分以外の名前を登録できるようにしておきました。)
このリストは入退社時に更新する従業員一覧スプレッドシートからデータと紐づいてます。これで入退社時に従業員一覧を更新すると貸出状況のドロップダウンリストも更新されます。

検索画面から読みたい本を絞り込むことも可能です。
↓ セキュリティで検索した結果

image.png

まとめ

AppSheetを使ってみて、気づいた点は以下の通り。

  1. 管理コンソールやヘルプページが全て英語です。最初は苦戦しますが、慣れてしまえば問題ないです。
  2. デザインのカスタマイズ性は高くありません。ノーコードあるあるです。いや、むしろデザインが固定されているからこそスピーディーにアプリケーションを作ることができるのです。これはまぎれもないメリットです。
  3. アプリを公開する際は、グループアドレスで共有できません。ひとつひとつ、気持ちを込めてユーザー登録しましょう。
  4. データベースのカラム名が他のデータベースと同じ名前にしちゃうとバグが発生しました。カラム名はかぶらないように決めたほうが良いです。

とはいえ、とても使い勝手のよいサービスだと実感しました。
備品や検証用スマホ端末管理もAppSheetで管理できたらなと思います。

さいごに
みなさーん、借りた本はちゃんと返してくださーい!


現在、Wanoグループでは人材募集をしています。興味のある方は下記を参照してください!

Wano | Wano Group JOBS

21
8
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
21
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?