<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
  <channel>
    <title>ShTips on tanaike - Google Apps Script, Gemini API, and Developer Tips</title>
    <link>https://tanaikech.github.io/topics/shtips/</link>
    <description>Recent content in ShTips on tanaike - Google Apps Script, Gemini API, and Developer Tips</description>
    <generator>Hugo</generator>
    <language>ja</language>
    <copyright>&amp;copy; 2026. All rights reserved.</copyright>
    <lastBuildDate>Tue, 09 May 2017 09:36:43 +0900</lastBuildDate>
    <atom:link href="https://tanaikech.github.io/topics/shtips/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>Delete Line Feed Code by DOS and Bash</title>
      <link>https://tanaikech.github.io/2017/05/09/delete-line-feed-code-by-dos-and-bash/</link>
      <pubDate>Tue, 09 May 2017 09:36:43 +0900</pubDate>
      <guid>https://tanaikech.github.io/2017/05/09/delete-line-feed-code-by-dos-and-bash/</guid>
      <description>&lt;h3 id=&#34;input-json&#34;&gt;Input JSON&lt;/h3&gt;&#xA;&lt;p&gt;&lt;strong&gt;text.txt :&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;&#34;&gt;&lt;code class=&#34;language-json&#34; data-lang=&#34;json&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;{&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;  &lt;span style=&#34;color:#f92672&#34;&gt;&amp;#34;values&amp;#34;&lt;/span&gt;: [&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    [&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;      &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;a1&amp;#34;&lt;/span&gt;,&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;      &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;b1&amp;#34;&lt;/span&gt;,&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;      &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;c1&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    ],&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    [&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;      &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;a2&amp;#34;&lt;/span&gt;,&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;      &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;b2&amp;#34;&lt;/span&gt;,&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;      &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;c2&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    ],&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    [&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;      &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;a3&amp;#34;&lt;/span&gt;,&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;      &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;b3&amp;#34;&lt;/span&gt;,&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;      &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;c3&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    ],&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    [&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;      &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;a4&amp;#34;&lt;/span&gt;,&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;      &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;b4&amp;#34;&lt;/span&gt;,&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;      &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;c4&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    ],&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    [&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;      &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;a5&amp;#34;&lt;/span&gt;,&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;      &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;b5&amp;#34;&lt;/span&gt;,&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;      &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;c5&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    ]&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;  ]&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;}&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h3 id=&#34;windows-dos&#34;&gt;Windows DOS&lt;/h3&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;&#34;&gt;&lt;code class=&#34;language-bash&#34; data-lang=&#34;bash&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;type text.txt | jq -c &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;.&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h3 id=&#34;linux-bash&#34;&gt;Linux Bash&lt;/h3&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;&#34;&gt;&lt;code class=&#34;language-bash&#34; data-lang=&#34;bash&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;$ cat text.txt | jq -c &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;.&amp;#39;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h3 id=&#34;output-json&#34;&gt;Output JSON&lt;/h3&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;&#34;&gt;&lt;code class=&#34;language-json&#34; data-lang=&#34;json&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;{&lt;span style=&#34;color:#f92672&#34;&gt;&amp;#34;values&amp;#34;&lt;/span&gt;:[[&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;a1&amp;#34;&lt;/span&gt;,&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;b1&amp;#34;&lt;/span&gt;,&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;c1&amp;#34;&lt;/span&gt;],[&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;a2&amp;#34;&lt;/span&gt;,&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;b2&amp;#34;&lt;/span&gt;,&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;c2&amp;#34;&lt;/span&gt;],[&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;a3&amp;#34;&lt;/span&gt;,&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;b3&amp;#34;&lt;/span&gt;,&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;c3&amp;#34;&lt;/span&gt;],[&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;a4&amp;#34;&lt;/span&gt;,&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;b4&amp;#34;&lt;/span&gt;,&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;c4&amp;#34;&lt;/span&gt;],[&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;a5&amp;#34;&lt;/span&gt;,&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;b5&amp;#34;&lt;/span&gt;,&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;c5&amp;#34;&lt;/span&gt;]]}&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;</description>
    </item>
    <item>
      <title>Add next row to current row using AWK</title>
      <link>https://tanaikech.github.io/2017/02/05/add-next-row-to-current-row-using-awk/</link>
      <pubDate>Sun, 05 Feb 2017 11:03:30 +0900</pubDate>
      <guid>https://tanaikech.github.io/2017/02/05/add-next-row-to-current-row-using-awk/</guid>
      <description>&lt;p&gt;&lt;strong&gt;File.txt :&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;a1&#xA;a2&#xA;a3&#xA;a4&#xA;a5&#xA;a6&#xA;&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;&lt;strong&gt;Code :&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;awk &amp;#39;{array[NR]=$0} END {for (i in array) {if (i&amp;gt;1) {{print array[i-1]&amp;#34;,&amp;#34;array[i]}}}}&amp;#39; File.txt&#xA;&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;&lt;strong&gt;Result :&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;a1,a2&#xA;a2,a3&#xA;a3,a4&#xA;a4,a5&#xA;a5,a6&#xA;&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;After the all rows are imported to an array, it shows next row to current row under a condition of row &amp;gt; 1.&lt;/p&gt;</description>
    </item>
    <item>
      <title>One Liner Code for Netatmo</title>
      <link>https://tanaikech.github.io/2017/01/11/one-liner-code-for-netatmo/</link>
      <pubDate>Wed, 11 Jan 2017 15:00:01 +0900</pubDate>
      <guid>https://tanaikech.github.io/2017/01/11/one-liner-code-for-netatmo/</guid>
      <description>&lt;p&gt;I made One Liner Code to retrieve data using Netatmo API. There are 2 ways. One is for windows dos. Another is for unix bash. Requirement tools are curl and jq.&lt;/p&gt;&#xA;&lt;h3 id=&#34;windows-dos&#34;&gt;windows dos&lt;/h3&gt;&#xA;&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;&amp;gt; setlocal &amp;amp; curl -s -d &amp;#34;grant_type=password&amp;amp;client_id=&amp;#39;#####&amp;#39;&amp;amp;client_secret=&amp;#39;#####&amp;#39;&amp;amp;username=&amp;#39;#####&amp;#39;&amp;amp;password=&amp;#39;#####&amp;#39;&amp;amp;scope=read_station&amp;#34; &amp;#34;https://api.netatmo.net/oauth2/token&amp;#34; | for /f &amp;#34;usebackq tokens=*&amp;#34; %a in (`jq -r &amp;#34;.access_token&amp;#34;`) do @set a=&amp;#34;%a&amp;#34; | curl -s -d &amp;#34;access_token=%a&amp;amp;device_id=&amp;#39;#####&amp;#39;&amp;#34; &amp;#34;https://api.netatmo.net/api/getstationsdata&amp;#34; &amp;gt; dat.txt &amp;amp; for /f &amp;#34;usebackq tokens=*&amp;#34; %b in (`jq -r &amp;#34;.body.devices[0].dashboard_data.Temperature&amp;#34; dat.txt`) do @set b=&amp;#34;%b&amp;#34; | echo: &amp;amp; set /p nb=Indoor: Temperature %b [degree C],&amp;lt;nul &amp;amp; for /f &amp;#34;usebackq tokens=*&amp;#34; %b in (`jq -r &amp;#34;.body.devices[0].dashboard_data.Humidity&amp;#34; dat.txt`) do @set b=&amp;#34;%b&amp;#34; | set /p nb=Humidity %b [%],&amp;lt;nul &amp;amp; for /f &amp;#34;usebackq tokens=*&amp;#34; %b in (`jq -r &amp;#34;.body.devices[0].dashboard_data.Pressure&amp;#34; dat.txt`) do @set b=&amp;#34;%b&amp;#34; | set /p nb=Pressure %b [hPa]&amp;lt;nul &amp;amp; for /f &amp;#34;usebackq tokens=*&amp;#34; %b in (`jq -r &amp;#34;.body.devices[0].modules[0].dashboard_data.Temperature&amp;#34; dat.txt`) do @set b=&amp;#34;%b&amp;#34; | echo: &amp;amp; set /p nb=Outdoor: Temperature %b [degree C],&amp;lt;nul &amp;amp; for /f &amp;#34;usebackq tokens=*&amp;#34; %b in (`jq -r &amp;#34;.body.devices[0].modules[0].dashboard_data.Humidity&amp;#34; dat.txt`) do @set b=&amp;#34;%b&amp;#34; | set /p nb=Humidity %b [%]&amp;lt;nul &amp;amp; del dat.txt&#xA;&#xA;Indoor: Temperature 12 [degree C],  Humidity 56 [%],  Pressure 1000.2 [hPa]&#xA;Outdoor: Temperature 12.3 [degree C],  Humidity 56 [%]&#xA;&lt;/code&gt;&lt;/pre&gt;&lt;h3 id=&#34;unix-bash&#34;&gt;unix bash&lt;/h3&gt;&#xA;&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;$ curl -s -d &amp;#34;grant_type=password&amp;amp;client_id=&amp;#39;#####&amp;#39;&amp;amp;client_secret=&amp;#39;#####&amp;#39;&amp;amp;username=&amp;#39;#####&amp;#39;&amp;amp;password=&amp;#39;#####&amp;#39;&amp;amp;scope=read_station&amp;#34; &amp;#34;https://api.netatmo.net/oauth2/token&amp;#34;|curl -s -d &amp;#34;access_token=`jq -r &amp;#39;.access_token&amp;#39;`&amp;amp;device_id=&amp;#39;#####&amp;#39;&amp;#34; &amp;#34;https://api.netatmo.net/api/getstationsdata&amp;#34;|jq -r &amp;#39;&amp;#34;\nIndoor: Temperature &amp;#34;+(.body.devices[0].dashboard_data.Temperature|tostring)+&amp;#34; [degree C], Humidity &amp;#34;+(.body.devices[0].dashboard_data.Humidity|tostring)+&amp;#34; [%], Pressure &amp;#34;+(.body.devices[0].dashboard_data.Pressure|tostring)+&amp;#34; [hPa]\nOutdoor: Temperature &amp;#34;+(.body.devices[0].modules[0].dashboard_data.Temperature|tostring)+&amp;#34; [degree C], Humidity &amp;#34;+(.body.devices[0].modules[0].dashboard_data.Humidity|tostring)+&amp;#34; [%]&amp;#34;&amp;#39;&#xA;&#xA;Indoor: Temperature 12 [degree C], Humidity 56 [%], Pressure 1000.2 [hPa]&#xA;Outdoor: Temperature 12.3 [degree C], Humidity 56 [%]&#xA;&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;If you want to use these One Liner Codes, you can use following code. Please replace &amp;ldquo;#####&amp;rdquo; to yours.&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
