エックスサーバーに最新バージョンのComposerをインストールする

参考する記事によってはPATHの反映がされなかったりだったので、メモ程度に。
サーバーへSSH接続までは省略します。

各バージョン確認

$composer -V
Composer version 1.10.26 2022-04-13 16:39:56

$php -v
PHP 5.4.16 (cli) (built: Apr  1 2020 04:07:17) 
Copyright (c) 1997-2013 The PHP Group
Zend Engine v2.4.0, Copyright (c) 1998-2013 Zend Technologies
    with Zend OPcache v7.0.5, Copyright (c) 1999-2015, by Zend Technologies

初期状態のPATHだと古いPHP・Composerのバージョンが使用されていると思うので、別のバージョンにPATHを通します。

今回は運用中のサイトで使用中のバージョンを使います。
Xserverサーバーパネルから現バージョンを確認します。

今回はPHP7.4 を使います。

1. PHP PATHを通す

既に存在するXserverのPHPにシンボリックリンクを作成します。
バージョンは各自調整してください。

$ cd
$ mkdir bin
$ ln -s /usr/bin/php7.4 $HOME/bin/php
$ ls -la $HOME/bin/

2. Composerをインストール

公式サイトのコマンド通りインストールします。
https://getcomposer.org/download/

php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
php -r "if (hash_file('sha384', 'composer-setup.php') === '55ce33d7678c5a611085589f1f3ddf8b3c52d662cd01d4ba75c0ee0459970c2200a51f492d557530c71c15d8dba01eae') { echo 'Installer verified'; } else { echo 'Installer corrupt'; unlink('composer-setup.php'); } echo PHP_EOL;"
php composer-setup.php
php -r "unlink('composer-setup.php');"

pharファイルを移動してPATHを通します。

mkdir -p .config/composer/vendor/bin/
mv composer.phar .config/composer/vendor/bin/composer
$vi .bash_profile

PATH=$HOME/.config/composer/vendor/bin:$HOME/bin:$PATH

3. .bash_profileを編集

PHPへのシンボリックリンク・ComposerへPATHを追加するため、1行追加します。

$vi .bash_profile

...
# 1行追加して保存
PATH=$HOME/.config/composer/vendor/bin:$HOME/bin:$PATH
...compose

# .bash_profileを反映
$ source .bash_profile

4. バージョン確認

$ composer -V
Composer version 2.2.21 2023-02-15 13:07:40

$ php -v
PHP 7.4.33 (cli) (built: Nov  1 2022 16:31:23) ( NTS )
Copyright (c) The PHP Group

バージョンアップ完了!

Google Maps APIのmarkerClustererでonClusterClickHandler を使う

markerClusterer onClusterClickHandler を使ってクリック後の制御を行う。

const onClusterClickHandler = (event, cluster, map) => {
    if (openInfoWindow) {
        openInfoWindow.close();
    }
    markerClusterer.defaultOnClusterClickHandler(event, cluster, map);
};
const markerCluster = new markerClusterer.MarkerClusterer({
    map,
    markers,
    onClusterClick: onClusterClickHandler
});

参考

https://github.com/googlemaps/js-markerclusterer/issues/623

導入

ここでは触れない。

Google Maps API: MarkerClustererのアイコンスタイルをカスタマイズする方法

Google Maps Marker Clustererのアイコンをカスタマイズしたかったのだが、書き方が大幅に変わっていたのでメモ

markerClusterer 該当コード

MarkerClustererのコード

参考: https://stackoverflow.com/questions/7834284/styling-markerclusterer-icons

<script src="https://unpkg.com/@googlemaps/markerclusterer/dist/index.min.js">
const renderer = {
            render: ({ count, position }) =>
                new google.maps.Marker({
                    icon: { url:"IMGURL" }, 
                    label: { text: String(count), color: "white", fontSize: "10px" },
                    position,
                    // adjust zIndex to be above other markers
                    zIndex: Number(google.maps.Marker.MAX_ZINDEX) + count,
            }),
            };
const markerCluster = new markerClusterer.MarkerClusterer({ 
                map, 
                markers,
                renderer,
            });

MarkerClustererPlusのコード

MarkerClustererPlusは非推奨らしい。ややこしい。
https://www.npmjs.com/package/@googlemaps/markerclustererplus

<script src="https://unpkg.com/@googlemaps/markerclustererplus/dist/index.min.js">
new MarkerClusterer(
  map,
  markers,
  {
    imagePath: 'https://developers.google.com/maps/documentation/javascript/examples/markerclusterer/m',
  },
);

導入

ここでは触れない。

JavaScriptでGoogle MapとMarkerClustererを使用してマーカーをまとめて表示する

GoogleMaps APIでSVGアイコンでマーカーを1000件ほど置いたら重くなったのでメモ。

マップ上に複数のマーカーを表示する場合、マーカーが重なってしまって見づらくなることがあります。そこで、MarkerClustererというJavaScriptライブラリを使用することで、マーカーをクラスタリングしてまとめて表示することができます。この記事では、Google MapとMarkerClustererを組み合わせて使い、マーカーを効果的にまとめて表示する方法について解説します。

とりあえず動くコード

<!DOCTYPE html>
<html>
<head>
    <title>Google Maps Marker Clusterer</title></script>
    <script src="https://unpkg.com/@googlemaps/markerclusterer/dist/index.min.js"></script>
    <script>
        function initMap() {
            const map = new google.maps.Map(document.getElementById("map"), {
                center: { lat: 37.7749, lng: -122.4194 },
                zoom: 10
            });

            const markers = [
                new google.maps.Marker({ position: { lat: 37.7749, lng: -122.4194 } }),
                new google.maps.Marker({ position: { lat: 37.7849, lng: -122.4194 } }),
                new google.maps.Marker({ position: { lat: 37.7949, lng: -122.4194 } })
            ];

            const markerCluster = new markerClusterer.MarkerClusterer({ map, markers });
        }
    </script>
    <script src="https://maps.googleapis.com/maps/api/js?key=APIKEY&callback=initMap">
</head>
<body>
    <div id="map" style="height: 400px;"></div>
</body>
</html>

公式ドキュメントのサンプルコードが動かない

https://developers.google.com/maps/documentation/javascript/overview?hl=ja#Inline

> 以下のサンプルは、この地図の作成に必要なコード全体を示しています。
> // Add a marker clusterer to manage the markers.
> new MarkerClusterer({ markers, map });

実行後
Uncaught ReferenceError: MarkerClusterer is not defined
    at initMap (test:21:13)
    at test:25:13

私がドキュメントを最後まで見てなかったのがいけなかったのですが。修正点。

Marker Clusterer を追加する手順は次のとおりです。
const markerCluster = new markerClusterer.MarkerClusterer({ map, markers });

以下詳細手順

1. Google Maps APIキーの取得:

Google Mapを使用するためには、まずGoogle Maps APIキーを取得する必要があります。Google Cloud Platformのプロジェクトを作成し、Maps JavaScript APIを有効化してAPIキーを生成します。

2. Google Mapsの初期設定:

HTMLファイルにGoogle Mapsを表示するための要素を追加し、JavaScriptコード内でその要素を取得します。また、APIキーを使用してGoogle Mapsを初期化します。

3. マーカーの作成と配置:

マーカーを表示する位置情報を定義し、Google Maps上にマーカーを配置します。マーカーの位置情報は緯度経度の形式で指定します。

4. MarkerClustererの設定:

MarkerClustererライブラリをインポートし、マーカーをクラスタリングするためのオプションを設定します。これにより、近くにあるマーカーがまとめて表示されます。

5. マーカーのクラスタリング:

MarkerClustererオブジェクトを作成し、マーカーをクラスタリングします。マーカーを追加するたびに、MarkerClustererが自動的にクラスタリングを更新します。

まとめて表示されたマーカーのスタイリング: クラスタリングされたマーカーにはデフォルトのスタイリングが適用されますが、必要に応じてスタイルをカスタマイズすることもできます。マーカーのアイコンやラベルなどを変更して、見栄えを調整しましょう。

Excelのセルの表示形式でダブルクォートを表示させる方法

Excelのセル表示でダブルクォートを表示させる方法です。

結論から書きます。

セルの表示形式: !"@!"

入力文字列: 千葉
表示: "千葉"
セルの表示形式: !"@"駅"!"

入力文字列: 千葉
表示: "千葉駅"

TEXT関数で書くと以下になります。

=TEXT(A1,"!""@!""")

だらだら説明

ダブルクォートをセルに直接表示させることは、通常の設定ではできません。しかし、特定の書式設定を使用することで、目的の表示を実現することができます。

まず、手順をご紹介します。

  1. Excelで対象のセルを選択します。
  2. ホームタブに移動し、「表示形式」セクションの「書式設定」をクリックします。
  3. 「書式設定」ダイアログボックスが表示されたら、「表示」タブを選択します。
  4. 「表示形式の種類」のリストから「カスタム」を選択します。
  5. 「タイプ」フィールドに以下のように入力します:
    !"@!" ここでは、@はテキストを表示するためのエスケープコードであり、!"はダブルクォートが表示されます。
  6. 「OK」をクリックして設定を適用します。

これで、セルに任意のテキスト(例:「東京タワー」)を入力すると、表示されるテキストは「”東京タワー”」となります。ダブルクォートが望んだ通りに表示されましたね!

ただし、この設定は表示上のみの変更であり、セルの値そのものには影響を与えません。他のセルでこのセルを参照する場合や計算に使用する場合は、通常のテキストと同じように扱われますのでご注意ください。

Excelの機能を上手に活用することで、さまざまな表示のカスタマイズが可能です。

便利なメール例文集!ビジネスで使えるフレーズをご紹介

はじめに

ビジネスの世界では、効果的なコミュニケーションが重要です。メールはその中でも特に頻繁に利用される手段の一つであり、相手に対して正確かつ明確なメッセージを伝えるためには、適切な文体やフレーズを使用することが求められます。本記事では、ビジネスシーンで役立つメール例文をいくつかご紹介しますので、ぜひ参考にしてみてください。

新規顧客へのご挨拶メール:

件名: 新規顧客へのご挨拶とご紹介
本文: お世話になっております。株式会社〇〇の××と申します。この度は、弊社の製品/サービスをご利用いただき、誠にありがとうございます。 ご不明な点やお困りごとがございましたら、いつでもお気軽にお問い合わせください。お客様のビジネスの成功に貢献できることを心より願っております。引き続き、どうぞよろしくお願い申し上げます。

プロジェクトの進捗報告メール:

件名: プロジェクト進捗報告と次のステップについて
本文: お世話になっております。現在進行中のプロジェクトに関して、以下の進捗報告をお知らせいたします。 〇〇の作業は順調に進んでおり、××のタスクも完了しました。ただし、△△の課題についてはまだ解決しておりませんので、引き続き検討が必要です。 次のステップについては、□□を実施する予定です。具体的なスケジュールについては別途ご連絡いたしますので、ご確認いただけますようお願い申し上げます。

取引条件の確認メール

件名: 取引条件の確認とご了承のお願い
本文: お世話になっております。この度は、弊社の商品をご注文いただき、誠にありがとうございます。 ご注文内容について、以下の取引条件をご確認いただきたく存じます。お手数をおかけしますが、ご了承いただけますようお願いいたします。

  • 商品名: 〇〇
  • 数量: ××個
  • 価格: ¥△△
  • 発送予定日: 年/月/日 なお、ご不明な点や修正がございましたら、お早めにご連絡ください。引き続き、ご愛顧賜りますようお願い申し上げます。

まとめ

上記は、ビジネスでよく使用されるシーンに対応したメール例文の一部です。しかし、重要なのは相手への丁寧さや明確さを意識したコミュニケーションですので、必ずしもこれらの例文をそのまま使用する必要はありません。状況や相手に合わせて適切な表現を選ぶことが肝要です。ぜひ、この例文を参考にしながら、自身のビジネスメールに役立ててください。

[学生向け] 企業面接を辞退したい メール例文

件名: 面接辞退のご連絡

尊敬する採用担当者様、

私は、先日ご応募させていただいた学生の〇〇と申します。この度は、面接の機会を与えていただき、誠にありがとうございました。

しかし、残念ながら私は、〇〇による理由で面接を辞退させていただきたく存じます。この理由について、以下に詳しく説明させていただきます。

〇〇により、私の日程が予想以上に制約されることとなりました。そのため、面接日時において十分な準備と集中を行うことができない恐れがあるため、面接を辞退させていただくことを決断いたしました。

誠に申し訳ございませんが、私の都合により、面接の日程を再調整することは難しい状況となっております。ただし、将来の機会がありましたら、再度ご応募させていただくことを希望いたします。

お手数をおかけいたしますが、面接辞退のご理解を賜りますようお願い申し上げます。また、採用プロセスにおいて順調な進行を心よりお祈り申し上げます。

何卒、ご容赦いただきますようお願い申し上げます。

敬具
〇〇

[企業向け]急ぎで見積もり依頼が欲しい時 メール例文

パターン1

件名: 見積もり依頼

[受取人の名前/役職],

[企業名] [お名前]と申します。[会社名]からの依頼で、お客様のご担当者様にお願いがございます。お手数ですが、お急ぎの見積もりの依頼をさせていただきたく、ご協力をお願い申し上げます。

私たちのプロジェクトにおいて、[製品/サービス]の必要性が生じており、可能な限り早く具体的な費用見積もりを頂戴できればと考えております。この見積もりは、今後の予算策定やプロジェクトの進行に必要不可欠な情報となります。

以下の詳細について、見積もりを提供していただけますでしょうか:

[製品/サービス]の数量と仕様
納品までの見積もり期間
費用の詳細(価格、税金、送料等)
支払い条件や方法について
もし可能であれば、[提供していただける見積もりの最終提出期限]までにご返信いただけますと幸いです。納期に追われており、迅速な対応が求められておりますので、お手数をおかけいたしますが、ご理解とご協力をいただければ幸いです。

ご不明点や補足がございましたら、お気軽にお知らせください。何卒よろしくお願い申し上げます。

敬具

[お名前]
[役職]
[会社名]
[連絡先情報]

パターン2

件名: お急ぎの見積もり依頼

拝啓 [受取人の名前/役職],

お世話になっております。私は[お名前]と申します。この度は、お忙しい中恐れ入りますが、お急ぎの見積もりの依頼をさせていただきたく、ご協力をお願いいたします。

弊社は[会社名]と申しまして、[製品/サービス]をご利用予定のプロジェクトに取り組んでおります。現在、進行中のプロジェクトにおいて、[製品/サービス]の具体的な費用を把握する必要があります。そのため、お早めに見積もりをいただけると大変助かります。

以下の詳細について、見積もりをお願いいたします:

[製品/サービス]の数量と仕様
納品までの見積もり期間
費用の詳細(価格、税金、送料等)
支払い条件や方法について
可能であれば、[提供していただける見積もりの最終提出期限]までにご返信いただけますと幸いです。プロジェクトの進行において迅速な判断が必要となっておりますので、お手数をおかけいたしますが、ご協力いただけますと幸いです。

何かご不明点や補足がございましたら、お気軽にお知らせください。引き続き、ご高配を賜りますようお願い申し上げます。

敬具

[お名前]
[役職]
[会社名]
[連絡先情報]

[企業向け]面接前の学生へのメール 例文

面接前の学生へのメール 例文です。

◯◯大学
◯◯ ◯◯◯さん

私たちの企業への興味をお示しいただき、誠にありがとうございます。私たちは、新たな才能と協力関係を築くために、大学生の皆さんとの面接を行う予定です。面接は、あなたの能力や経験を評価し、私たちの企業文化に適合するかどうかを判断するための重要な機会です。

以下に、面接時に役立ついくつかのポイントをご紹介いたします。

事前の準備
面接の前に、当社についての情報を調査し、ビジョンや価値観、業界動向などを把握しておくことをお勧めします。また、自己分析を行い、自身の強みや成果を明確に把握しておくことも重要です。

積極的なコミュニケーション
面接では、自身の意見やアイデアを明確に伝えることが求められます。自信を持って話すことで、私たちがあなたのポテンシャルを評価できるようにしてください。また、質問への回答には具体的な例やエピソードを交えることで、自身の経験を具体的に示すことが大切です。

チームプレイへの意識
私たちの企業では、協力やチームワークが非常に重要な価値観です。面接で、過去のチームプロジェクトや協力経験について話すことで、あなたのチームプレイ能力をアピールしてください。

質問への準備
面接では、あなた自身も質問をする機会が与えられます。私たちの企業やポジションに関する疑問や興味を持っていることを示すために、適切な質問を用意しておくことが重要です。

最後に、面接はあなたの能力やパーソナリティを正確に評価する機会です。緊張することもあるかもしれませんが、自信を持って臨んでください。私たちは、あなたとの面接を楽しみにしています。

ご質問や不明点があれば、お気軽にお問い合わせください。

デジタルトランスフォーメーションの成功に向けた鍵と戦略

現代のビジネス環境では、デジタルトランスフォーメーションが企業の競争力を高める重要な要素となっています。デジタルトランスフォーメーションは、テクノロジーの活用と組織文化の変革を通じて、業務プロセスの改善や新たなビジネスモデルの創出を実現する取り組みです。成功するためには、いくつかの鍵と戦略が必要です。

まず、デジタルトランスフォーメーションの鍵の一つは、リーダーシップと組織文化の変革です。経営陣は、デジタル変革のビジョンを明確にし、そのビジョンを従業員と共有する役割を果たす必要があります。また、組織全体の文化やプロセスを変革し、イノベーションや柔軟性を促進することも重要です。変革に向けた積極的なリーダーシップと文化の変化は、デジタルトランスフォーメーションの成功に欠かせません。

次に、データ駆動の戦略とテクノロジーの活用が重要です。デジタルトランスフォーメーションでは、データを中心に据えた意思決定と改善を行うことが求められます。データの収集、分析、洞察のための適切なテクノロジーの導入が不可欠です。ビッグデータ、人工知能、機械学習などのテクノロジーを活用し、データから洞察を得て、業務プロセスの最適化や新たなビジネスモデルの創出に活かすことが重要です。

さらに、エンゲージメントとスキルの開発もデジタルトランスフォーメーションの成功に欠かせません。従業員や顧客のエンゲージメントを高めるためには、デジタル体験の向上やコラボレーションの促進が重要です。また、デジタル技術を活用するためのスキルや能力を組織内に育成することも必要です。従業員の教育・訓練プログラムやパートナーシップの構築を通じて、デジタルスキルの向上と継続的な学習を推進することが重要です。

結論として、デジタルトランスフォーメーションの成功には、リーダーシップと組織文化の変革、データ駆動の戦略とテクノロジーの活用、エンゲージメントとスキルの開発が重要です。これらの要素をバランスよく取り入れながら、デジタルトランスフォーメーションに取り組むことで、企業は競争力を高め、持続可能な成長を実現できるでしょう。