以前、TwitterAPIを使った「ツイートを時間指定で自動削除する方法。」という記事を書きました。
自分で使っていて、ツイートが毎朝全削除されるのはかなり快適だったのですが、
ストックしておきたいツイート(読んだ記事や感想など)を残しておけなかったが不便だと感じていました。
素人ながら試行錯誤した結果、「特定のハッシュタグのツイートのみを削除対象から外す」ことに成功したのでまとめます。
[adsense]
目次
特定のハッシュタグを除いてツイートを削除するPHPファイルの作成
ソースコードはこちらの記事を参考にさせていただきました。
https://syncer.jp/Web/API/Twitter/REST_API/GET/search/tweets/
https://syncer.jp/Web/API/Twitter/REST_API/POST/statuses/destroy/id/
作成したのがこちらです。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 | <?php // 設定 $api_key = 'XXXXXXXXXXXXXXXX' ; // APIキー $api_secret = 'XXXXXXXXXXXXXXXX' ; // APIシークレット $access_token = 'XXXXXXXXXXXXXXXX' ; // アクセストークン $access_token_secret = 'XXXXXXXXXXXXXXXX' ; // アクセストークンシークレット $get_count = 100; // 取得件数(最大100件まで) $require_number = 10; //ループ回数 for ($i = 0; $i < $require_number; $i++) { // GET処理開始 // 設定 $request_url = 'https://api.twitter.com/1.1/search/tweets.json' ; // エンドポイント $request_method = 'GET' ; // パラメータA (オプション) $params_a = array( "q" => "from:@XXXXXX -#XXXXXXX", // アカウントIDと除外したいハッシュタグ名 'count' => $get_count , //"geocode" => "XXXXXXXXXX", //"lang" => "ja", //"locale" => "ja", //"result_type" => "popular", //"until" => "20XX-XX-XX", //"since_id" => "XXXXXXXXXX", //"max_id" => "XXXXXXXXXX", //"include_entities" => "true", ) ; // キーを作成する (URLエンコードする) $signature_key = rawurlencode( $api_secret ) . '&' . rawurlencode( $access_token_secret ) ; // パラメータB (署名の材料用) $params_b = array( 'oauth_token' => $access_token , 'oauth_consumer_key' => $api_key , 'oauth_signature_method' => 'HMAC-SHA1' , 'oauth_timestamp' => time() , 'oauth_nonce' => microtime() , 'oauth_version' => '1.0' , ) ; // パラメータAとパラメータBを合成してパラメータCを作る $params_c = array_merge( $params_a , $params_b ) ; // 連想配列をアルファベット順に並び替える ksort( $params_c ) ; // パラメータの連想配列を[キー=値&キー=値...]の文字列に変換する $request_params = http_build_query( $params_c , '' , '&' ) ; // 一部の文字列をフォロー $request_params = str_replace( array( '+' , '%7E' ) , array( '%20' , '~' ) , $request_params ) ; // 変換した文字列をURLエンコードする $request_params = rawurlencode( $request_params ) ; // リクエストメソッドをURLエンコードする // ここでは、URL末尾の[?]以下は付けないこと $encoded_request_method = rawurlencode( $request_method ) ; // リクエストURLをURLエンコードする $encoded_request_url = rawurlencode( $request_url ) ; // リクエストメソッド、リクエストURL、パラメータを[&]で繋ぐ $signature_data = $encoded_request_method . '&' . $encoded_request_url . '&' . $request_params ; // キー[$signature_key]とデータ[$signature_data]を利用して、HMAC-SHA1方式のハッシュ値に変換する $hash = hash_hmac( 'sha1' , $signature_data , $signature_key , TRUE ) ; // base64エンコードして、署名[$signature]が完成する $signature = base64_encode( $hash ) ; // パラメータの連想配列、[$params]に、作成した署名を加える $params_c['oauth_signature'] = $signature ; // パラメータの連想配列を[キー=値,キー=値,...]の文字列に変換する $header_params = http_build_query( $params_c , '' , ',' ) ; // リクエスト用のコンテキスト $context = array( 'http' => array( 'method' => $request_method , // リクエストメソッド 'header' => array( // ヘッダー 'Authorization: OAuth ' . $header_params , ) , ) , ) ; // パラメータがある場合、URLの末尾に追加 if( $params_a ) { $request_url .= '?' . http_build_query( $params_a ) ; } // オプションがある場合、コンテキストにPOSTフィールドを作成する (GETの場合は不要) // if( $params_a ) { // $context['http']['content'] = http_build_query( $params_a ) ; // } // cURLを使ってリクエスト $curl = curl_init() ; curl_setopt( $curl, CURLOPT_URL , $request_url ) ; curl_setopt( $curl, CURLOPT_HEADER, 1 ) ; curl_setopt( $curl, CURLOPT_CUSTOMREQUEST , $context['http']['method'] ) ; // メソッド curl_setopt( $curl, CURLOPT_SSL_VERIFYPEER , false ) ; // 証明書の検証を行わない curl_setopt( $curl, CURLOPT_RETURNTRANSFER , true ) ; // curl_execの結果を文字列で返す curl_setopt( $curl, CURLOPT_HTTPHEADER , $context['http']['header'] ) ; // ヘッダー // if( isset( $context['http']['content'] ) && !empty( $context['http']['content'] ) ) { // GETの場合は不要 // curl_setopt( $curl , CURLOPT_POSTFIELDS , $context['http']['content'] ) ; // リクエストボディ // } curl_setopt( $curl , CURLOPT_TIMEOUT , 5 ) ; // タイムアウトの秒数 $res1 = curl_exec( $curl ) ; $res2 = curl_getinfo( $curl ) ; curl_close( $curl ) ; // 取得したデータ $json = substr( $res1, $res2['header_size'] ) ; // 取得したデータ(JSONなど) $header = substr( $res1, 0, $res2['header_size'] ) ; // レスポンスヘッダー (検証に利用したい場合にどうぞ) // [cURL]ではなく、[file_get_contents()]を使うには下記の通りです… // $json = file_get_contents( $request_url , false , stream_context_create( $context ) ) ; // JSONをオブジェクトに変換 $obj = json_decode( $json ) ; //GET処理ここまで //POST処理開始 $request_method = 'POST' ; $count_num = 0; while ($obj->statuses[$count_num]->id != "") { $request_number = $obj->statuses[$count_num]->id; $request_url = 'https://api.twitter.com/1.1/statuses/destroy/' . $request_number . '.json' ; // エンドポイント // パラメータA (オプション) $params_a = array( // 'trim_user' => 'false' , // ユーザーオブジェクトの省略 ) ; // キーを作成する (URLエンコードする) $signature_key = rawurlencode( $api_secret ) . '&' . rawurlencode( $access_token_secret ) ; // パラメータB (署名の材料用) $params_b = array( 'oauth_token' => $access_token , 'oauth_consumer_key' => $api_key , 'oauth_signature_method' => 'HMAC-SHA1' , 'oauth_timestamp' => time() , 'oauth_nonce' => microtime() , 'oauth_version' => '1.0' , ) ; // パラメータAとパラメータBを合成してパラメータCを作る $params_c = array_merge( $params_a , $params_b ) ; // 連想配列をアルファベット順に並び替える ksort( $params_c ) ; // パラメータの連想配列を[キー=値&キー=値...]の文字列に変換する $request_params = http_build_query( $params_c , '' , '&' ) ; // 一部の文字列をフォロー $request_params = str_replace( array( '+' , '%7E' ) , array( '%20' , '~' ) , $request_params ) ; // 変換した文字列をURLエンコードする $request_params = rawurlencode( $request_params ) ; // リクエストメソッドをURLエンコードする // ここでは、URL末尾の[?]以下は付けないこと $encoded_request_method = rawurlencode( $request_method ) ; // リクエストURLをURLエンコードする $encoded_request_url = rawurlencode( $request_url ) ; // リクエストメソッド、リクエストURL、パラメータを[&]で繋ぐ $signature_data = $encoded_request_method . '&' . $encoded_request_url . '&' . $request_params ; // キー[$signature_key]とデータ[$signature_data]を利用して、HMAC-SHA1方式のハッシュ値に変換する $hash = hash_hmac( 'sha1' , $signature_data , $signature_key , TRUE ) ; // base64エンコードして、署名[$signature]が完成する $signature = base64_encode( $hash ) ; // パラメータの連想配列、[$params]に、作成した署名を加える $params_c['oauth_signature'] = $signature ; // パラメータの連想配列を[キー=値,キー=値,...]の文字列に変換する $header_params = http_build_query( $params_c , '' , ',' ) ; // リクエスト用のコンテキスト $context = array( 'http' => array( 'method' => $request_method , // リクエストメソッド 'header' => array( // ヘッダー 'Authorization: OAuth ' . $header_params , ) , ) , ) ; // オプションがある場合、コンテキストにPOSTフィールドを作成する if( $params_a ) { $context['http']['content'] = http_build_query( $params_a ) ; } // cURLを使ってリクエスト $curl = curl_init() ; curl_setopt( $curl , CURLOPT_URL , $request_url ) ; curl_setopt( $curl , CURLOPT_HEADER, 1 ) ; curl_setopt( $curl , CURLOPT_CUSTOMREQUEST , $context['http']['method'] ) ; // メソッド curl_setopt( $curl , CURLOPT_SSL_VERIFYPEER , false ) ; // 証明書の検証を行わない curl_setopt( $curl , CURLOPT_RETURNTRANSFER , true ) ; // curl_execの結果を文字列で返す curl_setopt( $curl , CURLOPT_HTTPHEADER , $context['http']['header'] ) ; // ヘッダー if( isset( $context['http']['content'] ) && !empty( $context['http']['content'] ) ) { curl_setopt( $curl , CURLOPT_POSTFIELDS , $context['http']['content'] ) ; // リクエストボディ } curl_setopt( $curl , CURLOPT_TIMEOUT , 5 ) ; // タイムアウトの秒数 $res1 = curl_exec( $curl ) ; $res2 = curl_getinfo( $curl ) ; curl_close( $curl ) ; // 取得したデータ $json = substr( $res1, $res2['header_size'] ) ; // 取得したデータ(JSONなど) $header = substr( $res1, 0, $res2['header_size'] ) ; // レスポンスヘッダー (検証に利用したい場合にどうぞ) $count_num++; } } ?> |
APIキーとかアクセストークンがわからない方
APIキーとかアクセストークンとか、わけわかめ!という方は、まずこちらをご覧ください。
仕組みをざっくりと説明します。
POST statuses/destroy/:id
1 | POST https://api.twitter.com/1.1/statuses/destroy/:id.json |
「:id」の部分に削除したいツイートのidを指定することで削除することができるというわけです。
ツイートのidを取得する方法が以下の方法です。
GET statuses/home_timeline
「ツイートを時間指定で自動削除する方法。」という記事では、
1 | GET https://api.twitter.com/1.1/statuses/home_timeline.json |
という、ホームタイムラインのツイートを取得するエンドポイントを使用していました。
これを使うことによってツイートに含まれる様々なデータを取得することができます。
その中にもちろん「id」も含まれています。
しかし、このエンドポイントで設定できるパラメータには「ハッシュタグ」が含まれていません。
よってこのエンドポイントでは、「特定のハッシュタグを除外する」ということができません。
GET search/tweets
その問題を解決するために、
1 | GET https://api.twitter.com/1.1/search/tweets.json |
というツイートを検索するエンドポイントを使います。
このエンドポイントでは、ツイッターの検索窓とほぼ同じの検索をすることができます。
例えば、ユーザー名やハッシュタグ、位置情報、時間などからツイートを検索することができます。
1 | "q" => "from:@XXXXXX -#XXXXXXX", // アカウントIDと除外したいハッシュタグ名 |
「q」というパラメータには、検索ワードを指定することができます。
今回の例では、誰のツイートでどのハッシュタグを除外するかということを指定します。
つまり、このエンドポイントを使うことで、「特定のハッシュタグを除く自分のツイート」を取得することができるということです。もちろんidも取得できます。
未検証ですが、こちらで紹介している検索演算子も使うことができるはずです。
https://www.howtonote.jp/twitter/index38.html
間違えやすいポイント
一番苦労したポイントは、「id」を出力して、ツイート削除のエンドポイントに埋め込むところです。
「ツイートを時間指定で自動削除する方法。」(GET statuses/home_timelineを利用)という記事で、紹介したコードでは、
1 2 3 4 | while ($obj[$count_num]["id"] != "") { $request_number = $obj[$count_num]["id"]; $request_url = 'https://api.twitter.com/1.1/statuses/destroy/' . $request_number . '.json' ; // エンドポイント |
$obj[$count_num][“id”]でツイートのidを出力することができていました。
(0番目のツイートのidを出力する場合は、$obj[0][“id”]で出力できました)
しかし、今回の「特定のハッシュタグを除く」場合、つまり「GET search/tweets」を使用する場合は、出力することができませんでした。
そこで、JSONデータを覗いてみたところ、
GET statuses/home_timelineでは、
1 2 3 4 5 | [ 0:{ created_at:XXXXXXXXXX id:XXXXXXXXXXX id_str:XXXXXXXXXX |
となっており、
GET search/tweetsでは、
1 2 3 4 5 6 7 8 9 | { statuses:[ 0:{ created_at:XXXXXXXX id:XXXXXXXXXXXXXXX id_str:XXXXXXXXXXX . . . |
となっていました。
構造が少し違ったんですね。(気付くのに時間がかかった、、、)
なのでidを取り出すには、「$obj[$count_num][“id”]」ではなく、
「$obj->statuses[$count_num]->id」としなければなりません。
つまり今回は、
1 2 3 4 | while ($obj->statuses[$count_num]->id != "") { $request_number = $obj->statuses[$count_num]->id; $request_url = 'https://api.twitter.com/1.1/statuses/destroy/' . $request_number . '.json' ; // エンドポイント |
とする必要がありました。
ちなみにJSONデータの扱いかたについてはここで勉強しました。
https://syncer.jp/how-to-use-json
時間指定で定期削除をする方法
ツイートを自動削除する方法、つまりPHPファイルを定期的に実行する方法についても、
以下の記事を御覧ください。
いいね!を定期的にリセットする方法
いいね!を定期的に解除する方法はこちらから。
わかりにくいところがあれば
わかりづらいところや、間違い、エラー等があれば、お気軽にお問い合わせください。
https://ytszk.info/blog/contact/
[adsense]
コメントを残す