{"id":31222,"date":"2023-01-15T22:16:43","date_gmt":"2023-03-18T01:50:36","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e7%94%a8java%e5%b0%86%e6%95%b0%e6%8d%ae%e5%86%99%e5%85%a5google-spreadsheet%e7%ac%ac%e4%ba%8c%e9%83%a8%e5%88%86%ef%bc%88java%e7%ab%af%ef%bc%89\/"},"modified":"2025-08-12T22:55:19","modified_gmt":"2025-08-12T14:55:19","slug":"%e7%94%a8java%e5%b0%86%e6%95%b0%e6%8d%ae%e5%86%99%e5%85%a5google-spreadsheet%e7%ac%ac%e4%ba%8c%e9%83%a8%e5%88%86%ef%bc%88java%e7%ab%af%ef%bc%89","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e7%94%a8java%e5%b0%86%e6%95%b0%e6%8d%ae%e5%86%99%e5%85%a5google-spreadsheet%e7%ac%ac%e4%ba%8c%e9%83%a8%e5%88%86%ef%bc%88java%e7%ab%af%ef%bc%89\/","title":{"rendered":"\u7528Java\u5c06\u6570\u636e\u5199\u5165Google Spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08Java\u7aef\uff09"},"content":{"rendered":"<p>http:\/\/qiita.com\/pilot\/items\/85bae4e5d5e35ffa7019 \u7684\u540e\u7eed\u5185\u5bb9<\/p>\n<h1>\u505a\u8fc7\u7684\u4e8b\u60c5 (zu\u00f2 gu\u00f2 de sh\u00ec<\/p>\n<h2>2. Java\u65b9\u9762\u4ee5\u4e0b\u662f\u5728Windows\u64cd\u4f5c\u7cfb\u7edf\u4e0a\u7684\u8868\u8fbe\u65b9\u5f0f\u3002<\/p>\n<p>\u4e3a\u4e86\u5c06\u6765\u5bfc\u5165Eclipse\u4e2d\u7684\u9879\u76ee\u76ee\u5f55\uff0c\u521b\u5efa\u4e00\u4e2a\u540d\u4e3a\u201cmytestapp1\u201d\u7684\u9879\u76ee\u76ee\u5f55\u3002<\/p>\n<p>\u5728\u8be5\u76ee\u5f55\u4e0b\u521b\u5efa\u4ee5\u4e0b\u6587\u4ef6<\/p>\n<pre class=\"post-pre\"><code><span class=\"n\">apply<\/span> <span class=\"nl\">plugin:<\/span> <span class=\"s2\">\"java\"<\/span>\r\n<span class=\"n\">apply<\/span> <span class=\"nl\">plugin:<\/span> <span class=\"s2\">\"application\"<\/span>\r\n<span class=\"n\">apply<\/span> <span class=\"nl\">plugin:<\/span> <span class=\"s2\">\"eclipse\"<\/span>\r\n\r\n<span class=\"k\">repositories<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"n\">mavenCentral<\/span><span class=\"o\">()<\/span>\r\n<span class=\"o\">}<\/span>\r\n<span class=\"k\">dependencies<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"n\">compile<\/span> <span class=\"s2\">\"com.google.api-client:google-api-client:1.22.0\"<\/span>\r\n    <span class=\"n\">compile<\/span> <span class=\"s2\">\"com.google.oauth-client:google-oauth-client-jetty:1.22.0\"<\/span>\r\n    <span class=\"n\">compile<\/span> <span class=\"s2\">\"com.google.apis:google-api-services-drive:v3-rev49-1.22.0\"<\/span>\r\n    <span class=\"n\">compile<\/span> <span class=\"s2\">\"com.google.apis:google-api-services-sheets:v4-rev34-1.22.0\"<\/span>\r\n    <span class=\"n\">compile<\/span> <span class=\"s2\">\"org.slf4j:slf4j-api:1.7.21\"<\/span>\r\n    <span class=\"n\">compile<\/span> <span class=\"s2\">\"org.slf4j:jul-to-slf4j:1.7.21\"<\/span> <span class=\"c1\">\/\/ Google\u30e9\u30a4\u30d6\u30e9\u30ea\u304cjava.util.logging\u3092\u4f7f\u3063\u3066\u3044\u308b\u305f\u3081<\/span>\r\n    <span class=\"n\">compile<\/span> <span class=\"s2\">\"ch.qos.logback:logback-classic:1.1.7\"<\/span>\r\n<span class=\"o\">}<\/span>\r\n\r\n<span class=\"n\">compileJava<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"n\">options<\/span><span class=\"o\">.<\/span><span class=\"na\">encoding<\/span> <span class=\"o\">=<\/span> <span class=\"s2\">\"UTF-8\"<\/span>\r\n<span class=\"o\">}<\/span>\r\n<span class=\"n\">sourceCompatibility<\/span> <span class=\"o\">=<\/span> <span class=\"s2\">\"1.8\"<\/span>\r\n<span class=\"n\">targetCompatibility<\/span> <span class=\"o\">=<\/span> <span class=\"s2\">\"1.8\"<\/span>\r\n<span class=\"n\">mainClassName<\/span> <span class=\"o\">=<\/span> <span class=\"s2\">\"mytestapp1.MyTestApp1\"<\/span>\r\n\r\n<span class=\"n\">task<\/span> <span class=\"nf\">wrapper<\/span><span class=\"o\">(<\/span><span class=\"nl\">type:<\/span> <span class=\"n\">Wrapper<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"n\">gradleVersion<\/span> <span class=\"o\">=<\/span> <span class=\"s2\">\"3.1\"<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<p>\u8fdb\u5165\u547d\u4ee4\u63d0\u793a\u7b26\uff0c\u5e76\u5728\u5f53\u524d\u76ee\u5f55\u4e0b\u6267\u884c\u4ee5\u4e0b\u64cd\u4f5c\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">mkdir src\\main\\java src\\main\\resources<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">gradle eclipse<\/ul>\n<p>\u4f7f\u7528Eclipse\u5bfc\u5165\u6307\u5b9a\u76ee\u5f55\uff08&#8221;\u5c06\u73b0\u6709\u9879\u76ee\u5bfc\u5165\u5de5\u4f5c\u533a&#8221;\uff09\u3002<\/p>\n<p>\u5728\u5b8c\u6210\u300c\u6b65\u9aa41\u300d\u540e\uff0c\u5c06\u4e0b\u8f7d\u7684JSON\u6587\u4ef6\u4ee5\u6587\u4ef6\u540d\u300cgoogle_client_secret.json\u300d\u4fdd\u5b58\u5728src\/main\/resources\u76ee\u5f55\u4e0b\u3002<\/p>\n<p>\u5728Eclipse\u4e0a\u521b\u5efa\u4ee5\u4e0b\u65b0\u7684\u7c7b\u548cXML\u6587\u4ef6\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kn\">package<\/span> <span class=\"nn\">mytestapp1<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.io.IOException<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.io.Reader<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.security.GeneralSecurityException<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.util.Collection<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.util.List<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.slf4j.Logger<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.slf4j.LoggerFactory<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.auth.oauth2.Credential<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.auth.oauth2.CredentialRefreshListener<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.auth.oauth2.TokenErrorResponse<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.auth.oauth2.TokenResponse<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.extensions.java6.auth.oauth2.AuthorizationCodeInstalledApp<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.extensions.jetty.auth.oauth2.LocalServerReceiver<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.googleapis.auth.oauth2.GoogleAuthorizationCodeFlow<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.googleapis.auth.oauth2.GoogleAuthorizationCodeFlow.Builder<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.googleapis.auth.oauth2.GoogleClientSecrets<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.googleapis.javanet.GoogleNetHttpTransport<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.http.HttpTransport<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.json.JsonFactory<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.json.jackson2.JacksonFactory<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.util.store.FileDataStoreFactory<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.drive.Drive<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.drive.model.File<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.sheets.v4.Sheets<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">GoogleService<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"kd\">final<\/span> <span class=\"nc\">Logger<\/span> <span class=\"no\">LOGGER<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">LoggerFactory<\/span><span class=\"o\">.<\/span><span class=\"na\">getLogger<\/span><span class=\"o\">(<\/span><span class=\"nc\">GoogleService<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">);<\/span>\r\n\r\n    <span class=\"c1\">\/\/ Global instance of the JSON factory.<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"kd\">final<\/span> <span class=\"nc\">JsonFactory<\/span> <span class=\"no\">JSON_FACTORY<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">JacksonFactory<\/span><span class=\"o\">.<\/span><span class=\"na\">getDefaultInstance<\/span><span class=\"o\">();<\/span>\r\n\r\n    <span class=\"c1\">\/\/ Global instance of the HTTP transport.<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"nc\">HttpTransport<\/span> <span class=\"no\">HTTP_TRANSPORT<\/span> <span class=\"o\">=<\/span> <span class=\"kc\">null<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"c1\">\/\/ Reader for client secret.<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">Reader<\/span> <span class=\"n\">clientSecretReader<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"c1\">\/\/ Collection of authorization scopes<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">Collection<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">String<\/span><span class=\"o\">&gt;<\/span> <span class=\"n\">authorizationScopes<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"c1\">\/\/ Directory to store user credentials<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">credentialStoreDirectory<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"c1\">\/\/ application name<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">applicationName<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"cm\">\/**\r\n     * Constructor.\r\n     *\r\n     * @param clientSecretReader reader for client secret\r\n     * @param authorizationScopes collection of authorization scopes\r\n     * @param credentialStoreDirectory directory to store user credentials\r\n     * @param applicationName application name\r\n     *\/<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"nf\">GoogleService<\/span><span class=\"o\">(<\/span><span class=\"nc\">Reader<\/span> <span class=\"n\">clientSecretReader<\/span><span class=\"o\">,<\/span> <span class=\"nc\">Collection<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">String<\/span><span class=\"o\">&gt;<\/span> <span class=\"n\">authorizationScopes<\/span><span class=\"o\">,<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">credentialStoreDirectory<\/span><span class=\"o\">,<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">applicationName<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"o\">.<\/span><span class=\"na\">clientSecretReader<\/span> <span class=\"o\">=<\/span> <span class=\"n\">clientSecretReader<\/span><span class=\"o\">;<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"o\">.<\/span><span class=\"na\">authorizationScopes<\/span> <span class=\"o\">=<\/span> <span class=\"n\">authorizationScopes<\/span><span class=\"o\">;<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"o\">.<\/span><span class=\"na\">credentialStoreDirectory<\/span> <span class=\"o\">=<\/span> <span class=\"n\">credentialStoreDirectory<\/span><span class=\"o\">;<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"o\">.<\/span><span class=\"na\">applicationName<\/span> <span class=\"o\">=<\/span> <span class=\"n\">applicationName<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"c1\">\/\/ Credential.<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">Credential<\/span> <span class=\"n\">credential<\/span> <span class=\"o\">=<\/span> <span class=\"kc\">null<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"cm\">\/**\r\n     * Creates an authorized Credential object.\r\n     *\r\n     * @throws IOException\r\n     * @throws GeneralSecurityException\r\n     *\/<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">authorize<\/span><span class=\"o\">()<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span><span class=\"o\">,<\/span> <span class=\"nc\">GeneralSecurityException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">if<\/span> <span class=\"o\">(<\/span><span class=\"n\">credential<\/span> <span class=\"o\">!=<\/span> <span class=\"kc\">null<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"k\">return<\/span><span class=\"o\">;<\/span>\r\n        <span class=\"o\">}<\/span>\r\n        <span class=\"c1\">\/\/ Load client secrets.<\/span>\r\n        <span class=\"nc\">GoogleClientSecrets<\/span> <span class=\"n\">clientSecrets<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">GoogleClientSecrets<\/span><span class=\"o\">.<\/span><span class=\"na\">load<\/span><span class=\"o\">(<\/span><span class=\"no\">JSON_FACTORY<\/span><span class=\"o\">,<\/span> <span class=\"n\">clientSecretReader<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"c1\">\/\/ instance of the {@link FileDataStoreFactory}.<\/span>\r\n        <span class=\"nc\">FileDataStoreFactory<\/span> <span class=\"n\">dataStoreFactory<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">FileDataStoreFactory<\/span><span class=\"o\">(<\/span><span class=\"k\">new<\/span> <span class=\"n\">java<\/span><span class=\"o\">.<\/span><span class=\"na\">io<\/span><span class=\"o\">.<\/span><span class=\"na\">File<\/span><span class=\"o\">(<\/span><span class=\"n\">credentialStoreDirectory<\/span><span class=\"o\">));<\/span>\r\n        <span class=\"c1\">\/\/ \u2191 Windows\u3067\u306f\u300cunable to change permissions\uff5e\u300d\u30ed\u30b0\u304c\u51fa\u529b\u3055\u308c\u308b<\/span>\r\n        <span class=\"k\">if<\/span> <span class=\"o\">(<\/span><span class=\"no\">HTTP_TRANSPORT<\/span> <span class=\"o\">==<\/span> <span class=\"kc\">null<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"no\">HTTP_TRANSPORT<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">GoogleNetHttpTransport<\/span><span class=\"o\">.<\/span><span class=\"na\">newTrustedTransport<\/span><span class=\"o\">();<\/span>\r\n        <span class=\"o\">}<\/span>\r\n        <span class=\"c1\">\/\/ Build flow and trigger user authorization request.<\/span>\r\n        <span class=\"nc\">Builder<\/span> <span class=\"n\">builder<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">GoogleAuthorizationCodeFlow<\/span><span class=\"o\">.<\/span><span class=\"na\">Builder<\/span><span class=\"o\">(<\/span><span class=\"no\">HTTP_TRANSPORT<\/span><span class=\"o\">,<\/span> <span class=\"no\">JSON_FACTORY<\/span><span class=\"o\">,<\/span> <span class=\"n\">clientSecrets<\/span><span class=\"o\">,<\/span> <span class=\"n\">authorizationScopes<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"n\">builder<\/span><span class=\"o\">.<\/span><span class=\"na\">setDataStoreFactory<\/span><span class=\"o\">(<\/span><span class=\"n\">dataStoreFactory<\/span><span class=\"o\">).<\/span><span class=\"na\">setAccessType<\/span><span class=\"o\">(<\/span><span class=\"s\">\"offline\"<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"c1\">\/\/ \u2191<\/span>\r\n        <span class=\"c1\">\/\/ AccessType\u300coffline\u300d\u3067RefreshToken\u3092\u5f97\u308b(AccessToken\u306eexpire\u524d60\u79d2\u4ee5\u5f8c\u306eAPI\u547c\u51fa\u6642\u306b\u81ea\u52d5refresh\u304c\u884c\u308f\u308c\u308b\u3088\u3046\u306b\u306a\u308b)<\/span>\r\n        <span class=\"n\">builder<\/span><span class=\"o\">.<\/span><span class=\"na\">addRefreshListener<\/span><span class=\"o\">(<\/span><span class=\"k\">new<\/span> <span class=\"nc\">CredentialRefreshListener<\/span><span class=\"o\">()<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"nd\">@Override<\/span>\r\n            <span class=\"kd\">public<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">onTokenResponse<\/span><span class=\"o\">(<\/span><span class=\"nc\">Credential<\/span> <span class=\"n\">credential<\/span><span class=\"o\">,<\/span> <span class=\"nc\">TokenResponse<\/span> <span class=\"n\">tokenResponse<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n                <span class=\"no\">LOGGER<\/span><span class=\"o\">.<\/span><span class=\"na\">info<\/span><span class=\"o\">(<\/span><span class=\"s\">\"AccessToken\u306erefresh\u304c\u6210\u529f\u3057\u307e\u3057\u305f\u3002(AccessToken=[{}], ExpiresInSeconds={}, RefreshToken=[{}])\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">credential<\/span><span class=\"o\">.<\/span><span class=\"na\">getAccessToken<\/span><span class=\"o\">(),<\/span> <span class=\"n\">credential<\/span><span class=\"o\">.<\/span><span class=\"na\">getExpiresInSeconds<\/span><span class=\"o\">(),<\/span> <span class=\"n\">credential<\/span><span class=\"o\">.<\/span><span class=\"na\">getRefreshToken<\/span><span class=\"o\">());<\/span>\r\n            <span class=\"o\">}<\/span>\r\n\r\n            <span class=\"nd\">@Override<\/span>\r\n            <span class=\"kd\">public<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">onTokenErrorResponse<\/span><span class=\"o\">(<\/span><span class=\"nc\">Credential<\/span> <span class=\"n\">credential<\/span><span class=\"o\">,<\/span> <span class=\"nc\">TokenErrorResponse<\/span> <span class=\"n\">tokenErrorResponse<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n                <span class=\"no\">LOGGER<\/span><span class=\"o\">.<\/span><span class=\"na\">error<\/span><span class=\"o\">(<\/span><span class=\"s\">\"AccessToken\u306erefresh\u304c\u5931\u6557\u3057\u307e\u3057\u305f\u3002(Error=[{}], ErrorDescription=[{}], ErrorUri=[{}])\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">tokenErrorResponse<\/span><span class=\"o\">.<\/span><span class=\"na\">getError<\/span><span class=\"o\">(),<\/span> <span class=\"n\">tokenErrorResponse<\/span><span class=\"o\">.<\/span><span class=\"na\">getErrorDescription<\/span><span class=\"o\">(),<\/span> <span class=\"n\">tokenErrorResponse<\/span><span class=\"o\">.<\/span><span class=\"na\">getErrorUri<\/span><span class=\"o\">());<\/span>\r\n            <span class=\"o\">}<\/span>\r\n        <span class=\"o\">});<\/span>\r\n        <span class=\"c1\">\/\/ \u2191 AccessToken\u306erefresh\u5f8c\u306eListner<\/span>\r\n        <span class=\"nc\">GoogleAuthorizationCodeFlow<\/span> <span class=\"n\">flow<\/span> <span class=\"o\">=<\/span> <span class=\"n\">builder<\/span><span class=\"o\">.<\/span><span class=\"na\">build<\/span><span class=\"o\">();<\/span>\r\n        <span class=\"n\">credential<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">AuthorizationCodeInstalledApp<\/span><span class=\"o\">(<\/span><span class=\"n\">flow<\/span><span class=\"o\">,<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">LocalServerReceiver<\/span><span class=\"o\">()).<\/span><span class=\"na\">authorize<\/span><span class=\"o\">(<\/span><span class=\"s\">\"user\"<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"c1\">\/\/ \u2191 \u521d\u56de\u306f\u30d6\u30e9\u30a6\u30b6\u304cGoogle\u306e\u8a31\u53ef\u30ea\u30af\u30a8\u30b9\u30c8\u753b\u9762\u3092\u8868\u793a\u3059\u308b(\u95a2\u9023\u30ed\u30b0\u3082\u51fa\u529b\u3055\u308c\u308b)<\/span>\r\n        <span class=\"c1\">\/\/ \u2192 \u300c\u8a31\u53ef\u300d\u62bc\u4e0b\u3067\u30ed\u30fc\u30ab\u30ebJetty\u306b\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u3055\u308c\u3001Credential\u304c\u30d5\u30a1\u30a4\u30eb\u306b\u4fdd\u5b58\u3055\u308c\u308b<\/span>\r\n        <span class=\"c1\">\/\/ \u2192 \u4ee5\u5f8c\u306fCredential\u30d5\u30a1\u30a4\u30eb\u304c\u3042\u308b\u9650\u308a\u30d6\u30e9\u30a6\u30b6\u306f\u8d77\u52d5\u3057\u306a\u3044(\u81ea\u52d5refresh\u306e\u304a\u304b\u3052)<\/span>\r\n        <span class=\"c1\">\/\/ \u2192 \u30b5\u30fc\u30d0\u3067\u5b9f\u884c\u3059\u308b\u5834\u5408\u306f\u30ed\u30fc\u30ab\u30ebPC\u3067\u4f5c\u6210\u3057\u305fCredential\u30d5\u30a1\u30a4\u30eb\u3092\u30b5\u30fc\u30d0\u306b\u914d\u7f6e\u3057\u3066\u304a\u304f<\/span>\r\n        <span class=\"c1\">\/\/ \u2192 \u4f55\u3089\u304b\u306e\u30a8\u30e9\u30fc\u3067\u30b5\u30fc\u30d0\u4e0a\u306eCredential\u30d5\u30a1\u30a4\u30eb\u304c\u7121\u52b9\u306b\u306a\u3063\u305f\u5834\u5408\u306f\u5f53\u6642\u306e\u30d5\u30a1\u30a4\u30eb\u3092\u518d\u5ea6\u914d\u7f6e\u3059\u308b<\/span>\r\n        <span class=\"no\">LOGGER<\/span><span class=\"o\">.<\/span><span class=\"na\">info<\/span><span class=\"o\">(<\/span><span class=\"s\">\"AccessToken\u3092\u53d6\u5f97\u3057\u307e\u3057\u305f\u3002(AccessToken=[{}], ExpiresInSeconds={}, RefreshToken=[{}])\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">credential<\/span><span class=\"o\">.<\/span><span class=\"na\">getAccessToken<\/span><span class=\"o\">(),<\/span> <span class=\"n\">credential<\/span><span class=\"o\">.<\/span><span class=\"na\">getExpiresInSeconds<\/span><span class=\"o\">(),<\/span> <span class=\"n\">credential<\/span><span class=\"o\">.<\/span><span class=\"na\">getRefreshToken<\/span><span class=\"o\">());<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"cm\">\/**\r\n     * Build and return an authorized Drive client service.\r\n     *\r\n     * @return an authorized Drive client service\r\n     * @throws GeneralSecurityException\r\n     * @throws IOException\r\n     *\/<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"nc\">Drive<\/span> <span class=\"nf\">getDriveService<\/span><span class=\"o\">()<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span><span class=\"o\">,<\/span> <span class=\"nc\">GeneralSecurityException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">if<\/span> <span class=\"o\">(<\/span><span class=\"n\">credential<\/span> <span class=\"o\">==<\/span> <span class=\"kc\">null<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"n\">authorize<\/span><span class=\"o\">();<\/span>\r\n        <span class=\"o\">}<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Drive<\/span><span class=\"o\">.<\/span><span class=\"na\">Builder<\/span><span class=\"o\">(<\/span><span class=\"no\">HTTP_TRANSPORT<\/span><span class=\"o\">,<\/span> <span class=\"no\">JSON_FACTORY<\/span><span class=\"o\">,<\/span> <span class=\"n\">credential<\/span><span class=\"o\">).<\/span><span class=\"na\">setApplicationName<\/span><span class=\"o\">(<\/span><span class=\"n\">applicationName<\/span><span class=\"o\">).<\/span><span class=\"na\">build<\/span><span class=\"o\">();<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"cm\">\/**\r\n     * Build and return an authorized Sheets API client service.\r\n     *\r\n     * @return an authorized Sheets API client service\r\n     * @throws GeneralSecurityException\r\n     * @throws IOException\r\n     *\/<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"nc\">Sheets<\/span> <span class=\"nf\">getSheetsService<\/span><span class=\"o\">()<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span><span class=\"o\">,<\/span> <span class=\"nc\">GeneralSecurityException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">if<\/span> <span class=\"o\">(<\/span><span class=\"n\">credential<\/span> <span class=\"o\">==<\/span> <span class=\"kc\">null<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"n\">authorize<\/span><span class=\"o\">();<\/span>\r\n        <span class=\"o\">}<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Sheets<\/span><span class=\"o\">.<\/span><span class=\"na\">Builder<\/span><span class=\"o\">(<\/span><span class=\"no\">HTTP_TRANSPORT<\/span><span class=\"o\">,<\/span> <span class=\"no\">JSON_FACTORY<\/span><span class=\"o\">,<\/span> <span class=\"n\">credential<\/span><span class=\"o\">).<\/span><span class=\"na\">setApplicationName<\/span><span class=\"o\">(<\/span><span class=\"n\">applicationName<\/span><span class=\"o\">).<\/span><span class=\"na\">build<\/span><span class=\"o\">();<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"nc\">SheetsWrapper<\/span> <span class=\"nf\">getSheetsWrapperWithWorksheet<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">folderName<\/span><span class=\"o\">,<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">spreadsheetName<\/span><span class=\"o\">,<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">worksheetName<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span><span class=\"o\">,<\/span> <span class=\"nc\">GeneralSecurityException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"nc\">DriveWrapper<\/span> <span class=\"n\">driveWrapper<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">DriveWrapper<\/span><span class=\"o\">(<\/span><span class=\"n\">getDriveService<\/span><span class=\"o\">());<\/span>\r\n        <span class=\"nc\">Sheets<\/span> <span class=\"n\">sheetsService<\/span> <span class=\"o\">=<\/span> <span class=\"n\">getSheetsService<\/span><span class=\"o\">();<\/span>\r\n\r\n        <span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">File<\/span><span class=\"o\">&gt;<\/span> <span class=\"n\">folderList<\/span> <span class=\"o\">=<\/span> <span class=\"n\">driveWrapper<\/span><span class=\"o\">.<\/span><span class=\"na\">searchFolder<\/span><span class=\"o\">(<\/span><span class=\"n\">folderName<\/span><span class=\"o\">,<\/span> <span class=\"nc\">DriveWrapper<\/span><span class=\"o\">.<\/span><span class=\"na\">ROOT_FOLDER_ID<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"c1\">\/\/ \u2191 AccessToken\u306eexpire\u524d60\u79d2\u4ee5\u5f8c\u3001\u3053\u3053\u3067AccessToken\u306erefresh\u304c\u5b9f\u884c\u3055\u308c\u308b<\/span>\r\n        <span class=\"nc\">String<\/span> <span class=\"n\">folderId<\/span> <span class=\"o\">=<\/span> <span class=\"kc\">null<\/span><span class=\"o\">;<\/span>\r\n        <span class=\"k\">if<\/span> <span class=\"o\">(<\/span><span class=\"n\">folderList<\/span><span class=\"o\">.<\/span><span class=\"na\">size<\/span><span class=\"o\">()<\/span> <span class=\"o\">==<\/span> <span class=\"mi\">0<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"n\">folderId<\/span> <span class=\"o\">=<\/span> <span class=\"n\">driveWrapper<\/span><span class=\"o\">.<\/span><span class=\"na\">createFolder<\/span><span class=\"o\">(<\/span><span class=\"n\">folderName<\/span><span class=\"o\">,<\/span> <span class=\"nc\">DriveWrapper<\/span><span class=\"o\">.<\/span><span class=\"na\">ROOT_FOLDER_ID<\/span><span class=\"o\">).<\/span><span class=\"na\">getId<\/span><span class=\"o\">();<\/span>\r\n            <span class=\"no\">LOGGER<\/span><span class=\"o\">.<\/span><span class=\"na\">info<\/span><span class=\"o\">(<\/span><span class=\"s\">\"\u30d5\u30a9\u30eb\u30c0 '{}' \u3092\u4f5c\u6210\u3057\u307e\u3057\u305f\u3002\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">folderName<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"o\">}<\/span> <span class=\"k\">else<\/span> <span class=\"k\">if<\/span> <span class=\"o\">(<\/span><span class=\"n\">folderList<\/span><span class=\"o\">.<\/span><span class=\"na\">size<\/span><span class=\"o\">()<\/span> <span class=\"o\">==<\/span> <span class=\"mi\">1<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"n\">folderId<\/span> <span class=\"o\">=<\/span> <span class=\"n\">folderList<\/span><span class=\"o\">.<\/span><span class=\"na\">get<\/span><span class=\"o\">(<\/span><span class=\"mi\">0<\/span><span class=\"o\">).<\/span><span class=\"na\">getId<\/span><span class=\"o\">();<\/span>\r\n        <span class=\"o\">}<\/span> <span class=\"k\">else<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"k\">throw<\/span> <span class=\"k\">new<\/span> <span class=\"nf\">IOException<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span><span class=\"o\">.<\/span><span class=\"na\">format<\/span><span class=\"o\">(<\/span><span class=\"s\">\"\u30d5\u30a9\u30eb\u30c0 '%s' \u304c\u8907\u6570\u5b58\u5728\u3057\u3066\u3044\u307e\u3059\u3002\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">folderName<\/span><span class=\"o\">));<\/span>\r\n        <span class=\"o\">}<\/span>\r\n\r\n        <span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">File<\/span><span class=\"o\">&gt;<\/span> <span class=\"n\">spreadsheetList<\/span> <span class=\"o\">=<\/span> <span class=\"n\">driveWrapper<\/span><span class=\"o\">.<\/span><span class=\"na\">searchSpreadsheet<\/span><span class=\"o\">(<\/span><span class=\"n\">spreadsheetName<\/span><span class=\"o\">,<\/span> <span class=\"n\">folderId<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"nc\">SheetsWrapper<\/span> <span class=\"n\">sheetsWrapper<\/span> <span class=\"o\">=<\/span> <span class=\"kc\">null<\/span><span class=\"o\">;<\/span>\r\n        <span class=\"k\">if<\/span> <span class=\"o\">(<\/span><span class=\"n\">spreadsheetList<\/span><span class=\"o\">.<\/span><span class=\"na\">size<\/span><span class=\"o\">()<\/span> <span class=\"o\">==<\/span> <span class=\"mi\">0<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"nc\">String<\/span> <span class=\"n\">spreadsheetId<\/span> <span class=\"o\">=<\/span> <span class=\"n\">driveWrapper<\/span><span class=\"o\">.<\/span><span class=\"na\">createSpreadsheet<\/span><span class=\"o\">(<\/span><span class=\"n\">spreadsheetName<\/span><span class=\"o\">,<\/span> <span class=\"n\">folderId<\/span><span class=\"o\">).<\/span><span class=\"na\">getId<\/span><span class=\"o\">();<\/span>\r\n            <span class=\"n\">sheetsWrapper<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">SheetsWrapper<\/span><span class=\"o\">(<\/span><span class=\"n\">sheetsService<\/span><span class=\"o\">,<\/span> <span class=\"n\">spreadsheetId<\/span><span class=\"o\">);<\/span>\r\n            <span class=\"no\">LOGGER<\/span><span class=\"o\">.<\/span><span class=\"na\">info<\/span><span class=\"o\">(<\/span><span class=\"s\">\"\u30b9\u30d7\u30ec\u30c3\u30c9\u30b7\u30fc\u30c8 '{}' \u3092\u4f5c\u6210\u3057\u307e\u3057\u305f\u3002\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">spreadsheetName<\/span><span class=\"o\">);<\/span>\r\n            <span class=\"n\">sheetsWrapper<\/span><span class=\"o\">.<\/span><span class=\"na\">renameWorksheet<\/span><span class=\"o\">(<\/span><span class=\"mi\">0<\/span><span class=\"o\">,<\/span> <span class=\"n\">worksheetName<\/span><span class=\"o\">);<\/span>\r\n            <span class=\"no\">LOGGER<\/span><span class=\"o\">.<\/span><span class=\"na\">info<\/span><span class=\"o\">(<\/span><span class=\"s\">\"\u30ef\u30fc\u30af\u30b7\u30fc\u30c8 '{}' \u3092\u4f5c\u6210\u3057\u307e\u3057\u305f\u3002\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">worksheetName<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"o\">}<\/span> <span class=\"k\">else<\/span> <span class=\"k\">if<\/span> <span class=\"o\">(<\/span><span class=\"n\">spreadsheetList<\/span><span class=\"o\">.<\/span><span class=\"na\">size<\/span><span class=\"o\">()<\/span> <span class=\"o\">==<\/span> <span class=\"mi\">1<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"nc\">String<\/span> <span class=\"n\">spreadsheetId<\/span> <span class=\"o\">=<\/span> <span class=\"n\">spreadsheetList<\/span><span class=\"o\">.<\/span><span class=\"na\">get<\/span><span class=\"o\">(<\/span><span class=\"mi\">0<\/span><span class=\"o\">).<\/span><span class=\"na\">getId<\/span><span class=\"o\">();<\/span>\r\n            <span class=\"n\">sheetsWrapper<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">SheetsWrapper<\/span><span class=\"o\">(<\/span><span class=\"n\">sheetsService<\/span><span class=\"o\">,<\/span> <span class=\"n\">spreadsheetId<\/span><span class=\"o\">);<\/span>\r\n            <span class=\"k\">if<\/span> <span class=\"o\">(<\/span><span class=\"n\">sheetsWrapper<\/span><span class=\"o\">.<\/span><span class=\"na\">getWorksheetProperties<\/span><span class=\"o\">(<\/span><span class=\"n\">worksheetName<\/span><span class=\"o\">)<\/span> <span class=\"o\">==<\/span> <span class=\"kc\">null<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n                <span class=\"n\">sheetsWrapper<\/span><span class=\"o\">.<\/span><span class=\"na\">addWorksheet<\/span><span class=\"o\">(<\/span><span class=\"n\">worksheetName<\/span><span class=\"o\">);<\/span>\r\n                <span class=\"no\">LOGGER<\/span><span class=\"o\">.<\/span><span class=\"na\">info<\/span><span class=\"o\">(<\/span><span class=\"s\">\"\u30ef\u30fc\u30af\u30b7\u30fc\u30c8 '{}' \u3092\u4f5c\u6210\u3057\u307e\u3057\u305f\u3002\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">worksheetName<\/span><span class=\"o\">);<\/span>\r\n            <span class=\"o\">}<\/span>\r\n        <span class=\"o\">}<\/span> <span class=\"k\">else<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"k\">throw<\/span> <span class=\"k\">new<\/span> <span class=\"nf\">IOException<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span><span class=\"o\">.<\/span><span class=\"na\">format<\/span><span class=\"o\">(<\/span><span class=\"s\">\"\u30b9\u30d7\u30ec\u30c3\u30c9\u30b7\u30fc\u30c8 '%s' \u304c\u8907\u6570\u5b58\u5728\u3057\u3066\u3044\u307e\u3059\u3002\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">spreadsheetName<\/span><span class=\"o\">));<\/span>\r\n        <span class=\"o\">}<\/span>\r\n\r\n        <span class=\"k\">return<\/span> <span class=\"n\">sheetsWrapper<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"kn\">package<\/span> <span class=\"nn\">mytestapp1<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.io.IOException<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.slf4j.Logger<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.slf4j.LoggerFactory<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.googleapis.json.GoogleJsonResponseException<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.client.googleapis.services.json.AbstractGoogleJsonClientRequest<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">RequestUtil<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"kd\">final<\/span> <span class=\"nc\">Logger<\/span> <span class=\"no\">LOGGER<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">LoggerFactory<\/span><span class=\"o\">.<\/span><span class=\"na\">getLogger<\/span><span class=\"o\">(<\/span><span class=\"nc\">RequestUtil<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">);<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"kd\">final<\/span> <span class=\"kt\">int<\/span> <span class=\"no\">RETRY_COUNT<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">10<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"kd\">final<\/span> <span class=\"kt\">int<\/span> <span class=\"no\">RETRY_INTERVAL_SECONDS<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">10<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"kd\">static<\/span> <span class=\"o\">&lt;<\/span><span class=\"no\">R<\/span> <span class=\"kd\">extends<\/span> <span class=\"nc\">AbstractGoogleJsonClientRequest<\/span><span class=\"o\">&lt;<\/span><span class=\"no\">T<\/span><span class=\"o\">&gt;,<\/span> <span class=\"no\">T<\/span><span class=\"o\">&gt;<\/span> <span class=\"no\">T<\/span> <span class=\"nf\">executeWithRetry<\/span><span class=\"o\">(<\/span><span class=\"no\">R<\/span> <span class=\"n\">request<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">for<\/span> <span class=\"o\">(<\/span><span class=\"kt\">int<\/span> <span class=\"n\">i<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">0<\/span><span class=\"o\">;<\/span> <span class=\"n\">i<\/span> <span class=\"o\">&lt;<\/span> <span class=\"o\">(<\/span><span class=\"no\">RETRY_COUNT<\/span> <span class=\"o\">-<\/span> <span class=\"mi\">1<\/span><span class=\"o\">);<\/span> <span class=\"n\">i<\/span><span class=\"o\">++)<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"k\">try<\/span> <span class=\"o\">{<\/span>\r\n                <span class=\"k\">return<\/span> <span class=\"n\">request<\/span><span class=\"o\">.<\/span><span class=\"na\">execute<\/span><span class=\"o\">();<\/span>\r\n            <span class=\"o\">}<\/span> <span class=\"k\">catch<\/span> <span class=\"o\">(<\/span><span class=\"nc\">GoogleJsonResponseException<\/span> <span class=\"n\">e<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n                <span class=\"k\">if<\/span> <span class=\"o\">(<\/span><span class=\"n\">e<\/span><span class=\"o\">.<\/span><span class=\"na\">getStatusCode<\/span><span class=\"o\">()<\/span> <span class=\"o\">==<\/span> <span class=\"mi\">503<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n                    <span class=\"no\">LOGGER<\/span><span class=\"o\">.<\/span><span class=\"na\">warn<\/span><span class=\"o\">(<\/span><span class=\"s\">\"Google\u304b\u3089\u30ea\u30c8\u30e9\u30a4\u53ef\u80fd\u306a\u30a8\u30e9\u30fc\u304c\u8fd4\u5374\u3055\u308c\u307e\u3057\u305f\u3002\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">e<\/span><span class=\"o\">);<\/span>\r\n                    <span class=\"no\">LOGGER<\/span><span class=\"o\">.<\/span><span class=\"na\">warn<\/span><span class=\"o\">(<\/span><span class=\"s\">\"{}\u79d2\u5f8c\u306b\u30ea\u30c8\u30e9\u30a4\u3092\u884c\u3044\u307e\u3059\u3002({}\/{}\u56de\u76ee)\"<\/span><span class=\"o\">,<\/span> <span class=\"no\">RETRY_INTERVAL_SECONDS<\/span> <span class=\"o\">*<\/span> <span class=\"o\">(<\/span><span class=\"n\">i<\/span> <span class=\"o\">+<\/span> <span class=\"mi\">1<\/span><span class=\"o\">),<\/span> <span class=\"n\">i<\/span> <span class=\"o\">+<\/span> <span class=\"mi\">1<\/span><span class=\"o\">,<\/span> <span class=\"no\">RETRY_COUNT<\/span><span class=\"o\">);<\/span>\r\n                    <span class=\"k\">try<\/span> <span class=\"o\">{<\/span>\r\n                        <span class=\"nc\">Thread<\/span><span class=\"o\">.<\/span><span class=\"na\">sleep<\/span><span class=\"o\">(<\/span><span class=\"no\">RETRY_INTERVAL_SECONDS<\/span> <span class=\"o\">*<\/span> <span class=\"o\">(<\/span><span class=\"n\">i<\/span> <span class=\"o\">+<\/span> <span class=\"mi\">1<\/span><span class=\"o\">)<\/span> <span class=\"o\">*<\/span> <span class=\"mi\">1000L<\/span><span class=\"o\">);<\/span>\r\n                    <span class=\"o\">}<\/span> <span class=\"k\">catch<\/span> <span class=\"o\">(<\/span><span class=\"nc\">InterruptedException<\/span> <span class=\"n\">e2<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n                        <span class=\"c1\">\/\/ do nothing<\/span>\r\n                    <span class=\"o\">}<\/span>\r\n                <span class=\"o\">}<\/span>\r\n            <span class=\"o\">}<\/span>\r\n        <span class=\"o\">}<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"n\">request<\/span><span class=\"o\">.<\/span><span class=\"na\">execute<\/span><span class=\"o\">();<\/span>\r\n    <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"kn\">package<\/span> <span class=\"nn\">mytestapp1<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.io.IOException<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.util.Arrays<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.util.List<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.drive.Drive<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.drive.model.File<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">DriveWrapper<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">Drive<\/span> <span class=\"n\">driveService<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"kd\">final<\/span> <span class=\"nc\">String<\/span> <span class=\"no\">QUERY_FORMAT<\/span> <span class=\"o\">=<\/span> <span class=\"s\">\"name = '%s' and '%s' in parents and mimeType = '%s' and trashed = false\"<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"kd\">final<\/span> <span class=\"nc\">String<\/span> <span class=\"no\">MIMETYPE_FOLDER<\/span> <span class=\"o\">=<\/span> <span class=\"s\">\"application\/vnd.google-apps.folder\"<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"kd\">final<\/span> <span class=\"nc\">String<\/span> <span class=\"no\">MIMETYPE_SPREADSHEET<\/span> <span class=\"o\">=<\/span> <span class=\"s\">\"application\/vnd.google-apps.spreadsheet\"<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"kd\">static<\/span> <span class=\"kd\">final<\/span> <span class=\"nc\">String<\/span> <span class=\"no\">ROOT_FOLDER_ID<\/span> <span class=\"o\">=<\/span> <span class=\"s\">\"root\"<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"nf\">DriveWrapper<\/span><span class=\"o\">(<\/span><span class=\"nc\">Drive<\/span> <span class=\"n\">driveService<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"o\">.<\/span><span class=\"na\">driveService<\/span> <span class=\"o\">=<\/span> <span class=\"n\">driveService<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">File<\/span><span class=\"o\">&gt;<\/span> <span class=\"nf\">searchFile<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">name<\/span><span class=\"o\">,<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">parentFolderId<\/span><span class=\"o\">,<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">mimeType<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"nc\">String<\/span> <span class=\"n\">query<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">String<\/span><span class=\"o\">.<\/span><span class=\"na\">format<\/span><span class=\"o\">(<\/span><span class=\"no\">QUERY_FORMAT<\/span><span class=\"o\">,<\/span> <span class=\"n\">name<\/span><span class=\"o\">,<\/span> <span class=\"n\">parentFolderId<\/span><span class=\"o\">,<\/span> <span class=\"n\">mimeType<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"nc\">RequestUtil<\/span><span class=\"o\">.<\/span><span class=\"na\">executeWithRetry<\/span><span class=\"o\">(<\/span><span class=\"n\">driveService<\/span><span class=\"o\">.<\/span><span class=\"na\">files<\/span><span class=\"o\">().<\/span><span class=\"na\">list<\/span><span class=\"o\">().<\/span><span class=\"na\">setQ<\/span><span class=\"o\">(<\/span><span class=\"n\">query<\/span><span class=\"o\">)).<\/span><span class=\"na\">getFiles<\/span><span class=\"o\">();<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">File<\/span><span class=\"o\">&gt;<\/span> <span class=\"nf\">searchFolder<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">name<\/span><span class=\"o\">,<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">parentFolderId<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"nf\">searchFile<\/span><span class=\"o\">(<\/span><span class=\"n\">name<\/span><span class=\"o\">,<\/span> <span class=\"n\">parentFolderId<\/span><span class=\"o\">,<\/span> <span class=\"no\">MIMETYPE_FOLDER<\/span><span class=\"o\">);<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">File<\/span><span class=\"o\">&gt;<\/span> <span class=\"nf\">searchSpreadsheet<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">name<\/span><span class=\"o\">,<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">parentFolderId<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"nf\">searchFile<\/span><span class=\"o\">(<\/span><span class=\"n\">name<\/span><span class=\"o\">,<\/span> <span class=\"n\">parentFolderId<\/span><span class=\"o\">,<\/span> <span class=\"no\">MIMETYPE_SPREADSHEET<\/span><span class=\"o\">);<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"nc\">File<\/span> <span class=\"nf\">createFile<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">name<\/span><span class=\"o\">,<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">parentFolderId<\/span><span class=\"o\">,<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">mimeType<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"nc\">File<\/span> <span class=\"n\">metadata<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">File<\/span><span class=\"o\">().<\/span><span class=\"na\">setName<\/span><span class=\"o\">(<\/span><span class=\"n\">name<\/span><span class=\"o\">).<\/span><span class=\"na\">setMimeType<\/span><span class=\"o\">(<\/span><span class=\"n\">mimeType<\/span><span class=\"o\">).<\/span><span class=\"na\">setParents<\/span><span class=\"o\">(<\/span><span class=\"nc\">Arrays<\/span><span class=\"o\">.<\/span><span class=\"na\">asList<\/span><span class=\"o\">(<\/span><span class=\"n\">parentFolderId<\/span><span class=\"o\">));<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"nc\">RequestUtil<\/span><span class=\"o\">.<\/span><span class=\"na\">executeWithRetry<\/span><span class=\"o\">(<\/span><span class=\"n\">driveService<\/span><span class=\"o\">.<\/span><span class=\"na\">files<\/span><span class=\"o\">().<\/span><span class=\"na\">create<\/span><span class=\"o\">(<\/span><span class=\"n\">metadata<\/span><span class=\"o\">));<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"nc\">File<\/span> <span class=\"nf\">createFolder<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">name<\/span><span class=\"o\">,<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">parentFolderId<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"nf\">createFile<\/span><span class=\"o\">(<\/span><span class=\"n\">name<\/span><span class=\"o\">,<\/span> <span class=\"n\">parentFolderId<\/span><span class=\"o\">,<\/span> <span class=\"no\">MIMETYPE_FOLDER<\/span><span class=\"o\">);<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"nc\">File<\/span> <span class=\"nf\">createSpreadsheet<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">name<\/span><span class=\"o\">,<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">parentFolderId<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"nf\">createFile<\/span><span class=\"o\">(<\/span><span class=\"n\">name<\/span><span class=\"o\">,<\/span> <span class=\"n\">parentFolderId<\/span><span class=\"o\">,<\/span> <span class=\"no\">MIMETYPE_SPREADSHEET<\/span><span class=\"o\">);<\/span>\r\n    <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"kn\">package<\/span> <span class=\"nn\">mytestapp1<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.io.IOException<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.util.ArrayList<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.util.Arrays<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.util.List<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.sheets.v4.Sheets<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.sheets.v4.model.AddSheetRequest<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.sheets.v4.model.BatchUpdateSpreadsheetRequest<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.sheets.v4.model.GridProperties<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.sheets.v4.model.Request<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.sheets.v4.model.Sheet<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.sheets.v4.model.SheetProperties<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.sheets.v4.model.Spreadsheet<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.sheets.v4.model.UpdateSheetPropertiesRequest<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.sheets.v4.model.ValueRange<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">SheetsWrapper<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">Sheets<\/span> <span class=\"n\">sheetsService<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">Spreadsheet<\/span> <span class=\"n\">spreadsheet<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"nf\">SheetsWrapper<\/span><span class=\"o\">(<\/span><span class=\"nc\">Sheets<\/span> <span class=\"n\">sheetsService<\/span><span class=\"o\">,<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">fileId<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"o\">.<\/span><span class=\"na\">sheetsService<\/span> <span class=\"o\">=<\/span> <span class=\"n\">sheetsService<\/span><span class=\"o\">;<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"o\">.<\/span><span class=\"na\">spreadsheet<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">RequestUtil<\/span><span class=\"o\">.<\/span><span class=\"na\">executeWithRetry<\/span><span class=\"o\">(<\/span><span class=\"n\">sheetsService<\/span><span class=\"o\">.<\/span><span class=\"na\">spreadsheets<\/span><span class=\"o\">().<\/span><span class=\"na\">get<\/span><span class=\"o\">(<\/span><span class=\"n\">fileId<\/span><span class=\"o\">).<\/span><span class=\"na\">setIncludeGridData<\/span><span class=\"o\">(<\/span><span class=\"kc\">false<\/span><span class=\"o\">));<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">renameWorksheet<\/span><span class=\"o\">(<\/span><span class=\"kt\">int<\/span> <span class=\"n\">index<\/span><span class=\"o\">,<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">newName<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"nc\">SheetProperties<\/span> <span class=\"n\">sheetProperties<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">SheetProperties<\/span><span class=\"o\">().<\/span><span class=\"na\">setIndex<\/span><span class=\"o\">(<\/span><span class=\"n\">index<\/span><span class=\"o\">).<\/span><span class=\"na\">setTitle<\/span><span class=\"o\">(<\/span><span class=\"n\">newName<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"nc\">UpdateSheetPropertiesRequest<\/span> <span class=\"n\">updateSheetPropertiesRequest<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">UpdateSheetPropertiesRequest<\/span><span class=\"o\">().<\/span><span class=\"na\">setProperties<\/span><span class=\"o\">(<\/span><span class=\"n\">sheetProperties<\/span><span class=\"o\">).<\/span><span class=\"na\">setFields<\/span><span class=\"o\">(<\/span><span class=\"s\">\"title\"<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">Request<\/span><span class=\"o\">&gt;<\/span> <span class=\"n\">requests<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">ArrayList<\/span><span class=\"o\">&lt;&gt;();<\/span>\r\n        <span class=\"n\">requests<\/span><span class=\"o\">.<\/span><span class=\"na\">add<\/span><span class=\"o\">(<\/span><span class=\"k\">new<\/span> <span class=\"nc\">Request<\/span><span class=\"o\">().<\/span><span class=\"na\">setUpdateSheetProperties<\/span><span class=\"o\">(<\/span><span class=\"n\">updateSheetPropertiesRequest<\/span><span class=\"o\">));<\/span>\r\n        <span class=\"nc\">RequestUtil<\/span><span class=\"o\">.<\/span><span class=\"na\">executeWithRetry<\/span><span class=\"o\">(<\/span><span class=\"n\">sheetsService<\/span><span class=\"o\">.<\/span><span class=\"na\">spreadsheets<\/span><span class=\"o\">().<\/span><span class=\"na\">batchUpdate<\/span><span class=\"o\">(<\/span><span class=\"n\">spreadsheet<\/span><span class=\"o\">.<\/span><span class=\"na\">getSpreadsheetId<\/span><span class=\"o\">(),<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">BatchUpdateSpreadsheetRequest<\/span><span class=\"o\">().<\/span><span class=\"na\">setRequests<\/span><span class=\"o\">(<\/span><span class=\"n\">requests<\/span><span class=\"o\">)));<\/span>\r\n        <span class=\"n\">spreadsheet<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">RequestUtil<\/span><span class=\"o\">.<\/span><span class=\"na\">executeWithRetry<\/span><span class=\"o\">(<\/span><span class=\"n\">sheetsService<\/span><span class=\"o\">.<\/span><span class=\"na\">spreadsheets<\/span><span class=\"o\">().<\/span><span class=\"na\">get<\/span><span class=\"o\">(<\/span><span class=\"n\">spreadsheet<\/span><span class=\"o\">.<\/span><span class=\"na\">getSpreadsheetId<\/span><span class=\"o\">()).<\/span><span class=\"na\">setIncludeGridData<\/span><span class=\"o\">(<\/span><span class=\"kc\">false<\/span><span class=\"o\">));<\/span>\r\n        <span class=\"c1\">\/\/ \u2191<\/span>\r\n        <span class=\"c1\">\/\/ rename\u5f8c\u306egetSheets().get().getProperties().getTitle()\u304crename\u524d\u306e\u5024\u3092\u8fd4\u3059\u554f\u984c\u306e\u5bfe\u5fdc<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"c1\">\/\/ \u898b\u3064\u304b\u3089\u306a\u3044\u3068\u304d\u306fnull\u3092\u8fd4\u3059<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"nc\">SheetProperties<\/span> <span class=\"nf\">getWorksheetProperties<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">worksheetName<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">for<\/span> <span class=\"o\">(<\/span><span class=\"kt\">int<\/span> <span class=\"n\">index<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">0<\/span><span class=\"o\">;<\/span> <span class=\"n\">index<\/span> <span class=\"o\">&lt;<\/span> <span class=\"n\">spreadsheet<\/span><span class=\"o\">.<\/span><span class=\"na\">getSheets<\/span><span class=\"o\">().<\/span><span class=\"na\">size<\/span><span class=\"o\">();<\/span> <span class=\"n\">index<\/span><span class=\"o\">++)<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"nc\">Sheet<\/span> <span class=\"n\">ws<\/span> <span class=\"o\">=<\/span> <span class=\"n\">spreadsheet<\/span><span class=\"o\">.<\/span><span class=\"na\">getSheets<\/span><span class=\"o\">().<\/span><span class=\"na\">get<\/span><span class=\"o\">(<\/span><span class=\"n\">index<\/span><span class=\"o\">);<\/span>\r\n            <span class=\"k\">if<\/span> <span class=\"o\">(<\/span><span class=\"n\">ws<\/span><span class=\"o\">.<\/span><span class=\"na\">getProperties<\/span><span class=\"o\">().<\/span><span class=\"na\">getTitle<\/span><span class=\"o\">().<\/span><span class=\"na\">equals<\/span><span class=\"o\">(<\/span><span class=\"n\">worksheetName<\/span><span class=\"o\">))<\/span> <span class=\"o\">{<\/span>\r\n                <span class=\"k\">return<\/span> <span class=\"n\">ws<\/span><span class=\"o\">.<\/span><span class=\"na\">getProperties<\/span><span class=\"o\">();<\/span>\r\n            <span class=\"o\">}<\/span>\r\n        <span class=\"o\">}<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"kc\">null<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">addWorksheet<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">worksheetName<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"nc\">SheetProperties<\/span> <span class=\"n\">sheetProperties<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">SheetProperties<\/span><span class=\"o\">().<\/span><span class=\"na\">setTitle<\/span><span class=\"o\">(<\/span><span class=\"n\">worksheetName<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"nc\">AddSheetRequest<\/span> <span class=\"n\">addSheetRequest<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">AddSheetRequest<\/span><span class=\"o\">().<\/span><span class=\"na\">setProperties<\/span><span class=\"o\">(<\/span><span class=\"n\">sheetProperties<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">Request<\/span><span class=\"o\">&gt;<\/span> <span class=\"n\">requests<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">ArrayList<\/span><span class=\"o\">&lt;&gt;();<\/span>\r\n        <span class=\"n\">requests<\/span><span class=\"o\">.<\/span><span class=\"na\">add<\/span><span class=\"o\">(<\/span><span class=\"k\">new<\/span> <span class=\"nc\">Request<\/span><span class=\"o\">().<\/span><span class=\"na\">setAddSheet<\/span><span class=\"o\">(<\/span><span class=\"n\">addSheetRequest<\/span><span class=\"o\">));<\/span>\r\n        <span class=\"nc\">RequestUtil<\/span><span class=\"o\">.<\/span><span class=\"na\">executeWithRetry<\/span><span class=\"o\">(<\/span><span class=\"n\">sheetsService<\/span><span class=\"o\">.<\/span><span class=\"na\">spreadsheets<\/span><span class=\"o\">().<\/span><span class=\"na\">batchUpdate<\/span><span class=\"o\">(<\/span><span class=\"n\">spreadsheet<\/span><span class=\"o\">.<\/span><span class=\"na\">getSpreadsheetId<\/span><span class=\"o\">(),<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">BatchUpdateSpreadsheetRequest<\/span><span class=\"o\">().<\/span><span class=\"na\">setRequests<\/span><span class=\"o\">(<\/span><span class=\"n\">requests<\/span><span class=\"o\">)));<\/span>\r\n        <span class=\"n\">spreadsheet<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">RequestUtil<\/span><span class=\"o\">.<\/span><span class=\"na\">executeWithRetry<\/span><span class=\"o\">(<\/span><span class=\"n\">sheetsService<\/span><span class=\"o\">.<\/span><span class=\"na\">spreadsheets<\/span><span class=\"o\">().<\/span><span class=\"na\">get<\/span><span class=\"o\">(<\/span><span class=\"n\">spreadsheet<\/span><span class=\"o\">.<\/span><span class=\"na\">getSpreadsheetId<\/span><span class=\"o\">()).<\/span><span class=\"na\">setIncludeGridData<\/span><span class=\"o\">(<\/span><span class=\"kc\">false<\/span><span class=\"o\">));<\/span>\r\n        <span class=\"c1\">\/\/ \u2191 add\u5f8c\u306egetSheets()\u304cadd\u3057\u305f\u30b7\u30fc\u30c8\u3092\u8fd4\u3055\u306a\u3044\u554f\u984c\u306e\u5bfe\u5fdc<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"c1\">\/\/ \u5024\u53d6\u5f97<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">Object<\/span><span class=\"o\">&gt;&gt;<\/span> <span class=\"nf\">getValues<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">worksheetName<\/span><span class=\"o\">,<\/span> <span class=\"kt\">int<\/span> <span class=\"n\">startColNum<\/span><span class=\"o\">,<\/span> <span class=\"kt\">int<\/span> <span class=\"n\">startRowNum<\/span><span class=\"o\">,<\/span> <span class=\"kt\">int<\/span> <span class=\"n\">endColNum<\/span><span class=\"o\">,<\/span> <span class=\"kt\">int<\/span> <span class=\"n\">endRowNum<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"kt\">boolean<\/span> <span class=\"n\">specifyColRow<\/span> <span class=\"o\">=<\/span> <span class=\"n\">startColNum<\/span> <span class=\"o\">&gt;<\/span> <span class=\"mi\">0<\/span> <span class=\"o\">||<\/span> <span class=\"n\">startRowNum<\/span> <span class=\"o\">&gt;<\/span> <span class=\"mi\">0<\/span> <span class=\"o\">||<\/span> <span class=\"n\">endColNum<\/span> <span class=\"o\">&gt;<\/span> <span class=\"mi\">0<\/span> <span class=\"o\">||<\/span> <span class=\"n\">endRowNum<\/span> <span class=\"o\">&gt;<\/span> <span class=\"mi\">0<\/span><span class=\"o\">;<\/span>\r\n        <span class=\"nc\">StringBuilder<\/span> <span class=\"n\">rangeBuf<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">StringBuilder<\/span><span class=\"o\">();<\/span>\r\n        <span class=\"n\">rangeBuf<\/span><span class=\"o\">.<\/span><span class=\"na\">append<\/span><span class=\"o\">(<\/span><span class=\"n\">worksheetName<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"n\">rangeBuf<\/span><span class=\"o\">.<\/span><span class=\"na\">append<\/span><span class=\"o\">(<\/span><span class=\"n\">specifyColRow<\/span> <span class=\"o\">?<\/span> <span class=\"sc\">'!'<\/span> <span class=\"o\">:<\/span> <span class=\"s\">\"\"<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"n\">rangeBuf<\/span><span class=\"o\">.<\/span><span class=\"na\">append<\/span><span class=\"o\">((<\/span><span class=\"n\">startColNum<\/span> <span class=\"o\">&gt;<\/span> <span class=\"mi\">0<\/span><span class=\"o\">)<\/span> <span class=\"o\">?<\/span> <span class=\"n\">bijectiveBase26<\/span><span class=\"o\">(<\/span><span class=\"n\">startColNum<\/span><span class=\"o\">)<\/span> <span class=\"o\">:<\/span> <span class=\"s\">\"\"<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"n\">rangeBuf<\/span><span class=\"o\">.<\/span><span class=\"na\">append<\/span><span class=\"o\">((<\/span><span class=\"n\">startRowNum<\/span> <span class=\"o\">&gt;<\/span> <span class=\"mi\">0<\/span><span class=\"o\">)<\/span> <span class=\"o\">?<\/span> <span class=\"n\">startRowNum<\/span> <span class=\"o\">:<\/span> <span class=\"s\">\"\"<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"n\">rangeBuf<\/span><span class=\"o\">.<\/span><span class=\"na\">append<\/span><span class=\"o\">(<\/span><span class=\"n\">specifyColRow<\/span> <span class=\"o\">?<\/span> <span class=\"sc\">':'<\/span> <span class=\"o\">:<\/span> <span class=\"s\">\"\"<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"n\">rangeBuf<\/span><span class=\"o\">.<\/span><span class=\"na\">append<\/span><span class=\"o\">((<\/span><span class=\"n\">endColNum<\/span> <span class=\"o\">&gt;<\/span> <span class=\"mi\">0<\/span><span class=\"o\">)<\/span> <span class=\"o\">?<\/span> <span class=\"n\">bijectiveBase26<\/span><span class=\"o\">(<\/span><span class=\"n\">endColNum<\/span><span class=\"o\">)<\/span> <span class=\"o\">:<\/span> <span class=\"s\">\"\"<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"n\">rangeBuf<\/span><span class=\"o\">.<\/span><span class=\"na\">append<\/span><span class=\"o\">((<\/span><span class=\"n\">endRowNum<\/span> <span class=\"o\">&gt;<\/span> <span class=\"mi\">0<\/span><span class=\"o\">)<\/span> <span class=\"o\">?<\/span> <span class=\"n\">endRowNum<\/span> <span class=\"o\">:<\/span> <span class=\"s\">\"\"<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"nc\">RequestUtil<\/span><span class=\"o\">.<\/span><span class=\"na\">executeWithRetry<\/span><span class=\"o\">(<\/span><span class=\"n\">sheetsService<\/span><span class=\"o\">.<\/span><span class=\"na\">spreadsheets<\/span><span class=\"o\">().<\/span><span class=\"na\">values<\/span><span class=\"o\">().<\/span><span class=\"na\">get<\/span><span class=\"o\">(<\/span><span class=\"n\">spreadsheet<\/span><span class=\"o\">.<\/span><span class=\"na\">getSpreadsheetId<\/span><span class=\"o\">(),<\/span> <span class=\"n\">rangeBuf<\/span><span class=\"o\">.<\/span><span class=\"na\">toString<\/span><span class=\"o\">())).<\/span><span class=\"na\">getValues<\/span><span class=\"o\">();<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"c1\">\/\/ \u6307\u5b9a\u5217\u3067\u5024\u306e\u5165\u3063\u3066\u3044\u308b\u6700\u5f8c\u306e\u884c\u306e\u884c\u756a\u53f7\u3092\u53d6\u5f97<\/span>\r\n    <span class=\"c1\">\/\/ (\u30ef\u30fc\u30af\u30b7\u30fc\u30c8\u540d\u306e\u307f\u6307\u5b9a\u3059\u308c\u3070\u300c\u5168\u5217\u3067\u300d\u3068\u306a\u308b\u304c\u30e1\u30e2\u30ea\u7bc0\u7d04\u306e\u305f\u3081\u5217\u6307\u5b9a\u3092\u3067\u304d\u308b\u3088\u3046\u306b\u3057\u3066\u304a\u304f)<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"kt\">int<\/span> <span class=\"nf\">getLastRowNumberWithValue<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">worksheetName<\/span><span class=\"o\">,<\/span> <span class=\"kt\">int<\/span> <span class=\"n\">colNum<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">Object<\/span><span class=\"o\">&gt;&gt;<\/span> <span class=\"n\">values<\/span> <span class=\"o\">=<\/span> <span class=\"n\">getValues<\/span><span class=\"o\">(<\/span><span class=\"n\">worksheetName<\/span><span class=\"o\">,<\/span> <span class=\"n\">colNum<\/span><span class=\"o\">,<\/span> <span class=\"mi\">0<\/span><span class=\"o\">,<\/span> <span class=\"n\">colNum<\/span><span class=\"o\">,<\/span> <span class=\"mi\">0<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"k\">if<\/span> <span class=\"o\">(<\/span><span class=\"n\">values<\/span> <span class=\"o\">!=<\/span> <span class=\"kc\">null<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"k\">return<\/span> <span class=\"n\">values<\/span><span class=\"o\">.<\/span><span class=\"na\">size<\/span><span class=\"o\">();<\/span>\r\n        <span class=\"o\">}<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"mi\">0<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"c1\">\/\/ \u5024\u66f8\u8fbc<\/span>\r\n    <span class=\"c1\">\/\/ \u6307\u5b9a\u5217\u30fb\u884c\u304c\u73fe\u5728\u306e\u30ef\u30fc\u30af\u30b7\u30fc\u30c8\u306e\u5927\u304d\u3055\u3092\u8d85\u3048\u308b\u5834\u5408\u306b\u306f\u30ef\u30fc\u30af\u30b7\u30fc\u30c8\u3092\u5fc5\u8981\u306a\u3060\u3051\u62e1\u5f35\u3059\u308b<\/span>\r\n    <span class=\"c1\">\/\/ \u6307\u5b9a\u4f4d\u7f6e\u306b\u65e2\u5b58\u306e\u5024\u304c\u3042\u308c\u3070\u4e0a\u66f8\u304d\u3059\u308b<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">setValues<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">worksheetName<\/span><span class=\"o\">,<\/span> <span class=\"kt\">int<\/span> <span class=\"n\">startColNum<\/span><span class=\"o\">,<\/span> <span class=\"kt\">int<\/span> <span class=\"n\">startRowNum<\/span><span class=\"o\">,<\/span> <span class=\"nc\">Object<\/span><span class=\"o\">[][]<\/span> <span class=\"n\">values<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">Object<\/span><span class=\"o\">&gt;&gt;<\/span> <span class=\"n\">valueList<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">ArrayList<\/span><span class=\"o\">&lt;&gt;();<\/span>\r\n        <span class=\"k\">for<\/span> <span class=\"o\">(<\/span><span class=\"nc\">Object<\/span><span class=\"o\">[]<\/span> <span class=\"n\">row<\/span> <span class=\"o\">:<\/span> <span class=\"n\">values<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"n\">valueList<\/span><span class=\"o\">.<\/span><span class=\"na\">add<\/span><span class=\"o\">(<\/span><span class=\"nc\">Arrays<\/span><span class=\"o\">.<\/span><span class=\"na\">asList<\/span><span class=\"o\">(<\/span><span class=\"n\">row<\/span><span class=\"o\">));<\/span>\r\n        <span class=\"o\">}<\/span>\r\n        <span class=\"n\">setValues<\/span><span class=\"o\">(<\/span><span class=\"n\">worksheetName<\/span><span class=\"o\">,<\/span> <span class=\"n\">startColNum<\/span><span class=\"o\">,<\/span> <span class=\"n\">startRowNum<\/span><span class=\"o\">,<\/span> <span class=\"n\">valueList<\/span><span class=\"o\">);<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">setValues<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">worksheetName<\/span><span class=\"o\">,<\/span> <span class=\"kt\">int<\/span> <span class=\"n\">startColNum<\/span><span class=\"o\">,<\/span> <span class=\"kt\">int<\/span> <span class=\"n\">startRowNum<\/span><span class=\"o\">,<\/span> <span class=\"nc\">Object<\/span><span class=\"o\">[]<\/span> <span class=\"n\">values<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"n\">setValues<\/span><span class=\"o\">(<\/span><span class=\"n\">worksheetName<\/span><span class=\"o\">,<\/span> <span class=\"n\">startColNum<\/span><span class=\"o\">,<\/span> <span class=\"n\">startRowNum<\/span><span class=\"o\">,<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Object<\/span><span class=\"o\">[][]<\/span> <span class=\"o\">{<\/span> <span class=\"n\">values<\/span> <span class=\"o\">});<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">setValue<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">worksheetName<\/span><span class=\"o\">,<\/span> <span class=\"kt\">int<\/span> <span class=\"n\">colNum<\/span><span class=\"o\">,<\/span> <span class=\"kt\">int<\/span> <span class=\"n\">rowNum<\/span><span class=\"o\">,<\/span> <span class=\"nc\">Object<\/span> <span class=\"n\">value<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"n\">setValues<\/span><span class=\"o\">(<\/span><span class=\"n\">worksheetName<\/span><span class=\"o\">,<\/span> <span class=\"n\">colNum<\/span><span class=\"o\">,<\/span> <span class=\"n\">rowNum<\/span><span class=\"o\">,<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Object<\/span><span class=\"o\">[][]<\/span> <span class=\"o\">{<\/span> <span class=\"o\">{<\/span> <span class=\"n\">value<\/span> <span class=\"o\">}<\/span> <span class=\"o\">});<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">setValues<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">worksheetName<\/span><span class=\"o\">,<\/span> <span class=\"kt\">int<\/span> <span class=\"n\">startColNum<\/span><span class=\"o\">,<\/span> <span class=\"kt\">int<\/span> <span class=\"n\">startRowNum<\/span><span class=\"o\">,<\/span> <span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">Object<\/span><span class=\"o\">&gt;&gt;<\/span> <span class=\"n\">valueList<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"nc\">ValueRange<\/span> <span class=\"n\">valueRange<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">ValueRange<\/span><span class=\"o\">().<\/span><span class=\"na\">setValues<\/span><span class=\"o\">(<\/span><span class=\"n\">valueList<\/span><span class=\"o\">).<\/span><span class=\"na\">setMajorDimension<\/span><span class=\"o\">(<\/span><span class=\"s\">\"ROWS\"<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"nc\">String<\/span> <span class=\"n\">range<\/span> <span class=\"o\">=<\/span> <span class=\"n\">worksheetName<\/span> <span class=\"o\">+<\/span> <span class=\"s\">\"!\"<\/span> <span class=\"o\">+<\/span> <span class=\"n\">bijectiveBase26<\/span><span class=\"o\">(<\/span><span class=\"n\">startColNum<\/span><span class=\"o\">)<\/span> <span class=\"o\">+<\/span> <span class=\"n\">startRowNum<\/span><span class=\"o\">;<\/span>\r\n        <span class=\"c1\">\/\/ \u958b\u59cb\u4f4d\u7f6e\u304c\u7bc4\u56f2\u5185\u306a\u3089update\u3001\u7bc4\u56f2\u5916\u306a\u3089append<\/span>\r\n        <span class=\"c1\">\/\/ (update\u306f\u958b\u59cb\u4f4d\u7f6e\u304c\u7bc4\u56f2\u5916\u3060\u3068\u30a8\u30e9\u30fc\u3001\u958b\u59cb\u4f4d\u7f6e\u3055\u3048\u7bc4\u56f2\u5185\u306a\u3089\u305d\u306e\u5f8c\u306f\u5fc5\u8981\u306b\u5fdc\u3058\u3066\u5217\u30fb\u884c\u3092\u8ffd\u52a0\u3057\u3066\u304f\u308c\u308b)<\/span>\r\n        <span class=\"c1\">\/\/ (append\u306f\u958b\u59cb\u4f4d\u7f6e\u304c\u7bc4\u56f2\u5916\u3067\u3082\u5fc5\u8981\u306b\u5fdc\u3058\u3066\u5217\u30fb\u884c\u3092\u8ffd\u52a0\u3057\u3066\u304f\u308c\u308b\u304c\u3001\u958b\u59cb\u4f4d\u7f6e\u304c\u7a7a\u304c\u306a\u3044\u5834\u5408\u306b\u4e0a\u66f8\u304d\u3057\u3066\u304f\u308c\u306a\u3044)<\/span>\r\n        <span class=\"nc\">GridProperties<\/span> <span class=\"n\">gridProperties<\/span> <span class=\"o\">=<\/span> <span class=\"n\">getWorksheetProperties<\/span><span class=\"o\">(<\/span><span class=\"n\">worksheetName<\/span><span class=\"o\">).<\/span><span class=\"na\">getGridProperties<\/span><span class=\"o\">();<\/span>\r\n        <span class=\"k\">if<\/span> <span class=\"o\">(<\/span><span class=\"n\">startColNum<\/span> <span class=\"o\">&lt;=<\/span> <span class=\"n\">gridProperties<\/span><span class=\"o\">.<\/span><span class=\"na\">getColumnCount<\/span><span class=\"o\">()<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"n\">startRowNum<\/span> <span class=\"o\">&lt;=<\/span> <span class=\"n\">gridProperties<\/span><span class=\"o\">.<\/span><span class=\"na\">getRowCount<\/span><span class=\"o\">())<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"nc\">RequestUtil<\/span><span class=\"o\">.<\/span><span class=\"na\">executeWithRetry<\/span><span class=\"o\">(<\/span><span class=\"n\">sheetsService<\/span><span class=\"o\">.<\/span><span class=\"na\">spreadsheets<\/span><span class=\"o\">().<\/span><span class=\"na\">values<\/span><span class=\"o\">().<\/span><span class=\"na\">update<\/span><span class=\"o\">(<\/span><span class=\"n\">spreadsheet<\/span><span class=\"o\">.<\/span><span class=\"na\">getSpreadsheetId<\/span><span class=\"o\">(),<\/span> <span class=\"n\">range<\/span><span class=\"o\">,<\/span> <span class=\"n\">valueRange<\/span><span class=\"o\">).<\/span><span class=\"na\">setValueInputOption<\/span><span class=\"o\">(<\/span><span class=\"s\">\"USER_ENTERED\"<\/span><span class=\"o\">));<\/span>\r\n        <span class=\"o\">}<\/span> <span class=\"k\">else<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"nc\">RequestUtil<\/span><span class=\"o\">.<\/span><span class=\"na\">executeWithRetry<\/span><span class=\"o\">(<\/span><span class=\"n\">sheetsService<\/span><span class=\"o\">.<\/span><span class=\"na\">spreadsheets<\/span><span class=\"o\">().<\/span><span class=\"na\">values<\/span><span class=\"o\">().<\/span><span class=\"na\">append<\/span><span class=\"o\">(<\/span><span class=\"n\">spreadsheet<\/span><span class=\"o\">.<\/span><span class=\"na\">getSpreadsheetId<\/span><span class=\"o\">(),<\/span> <span class=\"n\">range<\/span><span class=\"o\">,<\/span> <span class=\"n\">valueRange<\/span><span class=\"o\">).<\/span><span class=\"na\">setValueInputOption<\/span><span class=\"o\">(<\/span><span class=\"s\">\"USER_ENTERED\"<\/span><span class=\"o\">));<\/span>\r\n        <span class=\"o\">}<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"c1\">\/\/ \u5217\u756a\u53f7\u3092\u5217\u756a\u53f7\u6587\u5b57\u5217\u306b\u5909\u63db\u3059\u308b<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">String<\/span> <span class=\"nf\">bijectiveBase26<\/span><span class=\"o\">(<\/span><span class=\"kt\">int<\/span> <span class=\"n\">n<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"c1\">\/\/ https:\/\/gist.github.com\/theazureshadow\/4a5a032944f1c9bc0f4a \u3088\u308a<\/span>\r\n        <span class=\"nc\">StringBuilder<\/span> <span class=\"n\">buf<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">StringBuilder<\/span><span class=\"o\">();<\/span>\r\n        <span class=\"k\">while<\/span> <span class=\"o\">(<\/span><span class=\"n\">n<\/span> <span class=\"o\">!=<\/span> <span class=\"mi\">0<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"n\">buf<\/span><span class=\"o\">.<\/span><span class=\"na\">append<\/span><span class=\"o\">((<\/span><span class=\"kt\">char<\/span><span class=\"o\">)<\/span> <span class=\"o\">((<\/span><span class=\"n\">n<\/span> <span class=\"o\">-<\/span> <span class=\"mi\">1<\/span><span class=\"o\">)<\/span> <span class=\"o\">%<\/span> <span class=\"mi\">26<\/span> <span class=\"o\">+<\/span> <span class=\"sc\">'A'<\/span><span class=\"o\">));<\/span>\r\n            <span class=\"n\">n<\/span> <span class=\"o\">=<\/span> <span class=\"o\">(<\/span><span class=\"n\">n<\/span> <span class=\"o\">-<\/span> <span class=\"mi\">1<\/span><span class=\"o\">)<\/span> <span class=\"o\">\/<\/span> <span class=\"mi\">26<\/span><span class=\"o\">;<\/span>\r\n        <span class=\"o\">}<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"n\">buf<\/span><span class=\"o\">.<\/span><span class=\"na\">reverse<\/span><span class=\"o\">().<\/span><span class=\"na\">toString<\/span><span class=\"o\">();<\/span>\r\n    <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"kn\">package<\/span> <span class=\"nn\">mytestapp1<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.io.IOException<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.security.GeneralSecurityException<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.slf4j.Logger<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.slf4j.LoggerFactory<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.slf4j.bridge.SLF4JBridgeHandler<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"cm\">\/**\r\n * Google\u8a8d\u8a3c\u3092\u884c\u3044\u3001Credential\u30d5\u30a1\u30a4\u30eb\u3092\u4f5c\u6210\u3059\u308b\u3002\r\n *\/<\/span>\r\n<span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">CreateCredentialFile<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"kd\">final<\/span> <span class=\"nc\">Logger<\/span> <span class=\"no\">LOGGER<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">LoggerFactory<\/span><span class=\"o\">.<\/span><span class=\"na\">getLogger<\/span><span class=\"o\">(<\/span><span class=\"nc\">CreateCredentialFile<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">);<\/span>\r\n\r\n    <span class=\"cm\">\/**\r\n     * Google\u8a8d\u8a3c\u3092\u884c\u3044\u3001Credential\u30d5\u30a1\u30a4\u30eb\u3092\u4f5c\u6210\u3059\u308b\u3002&lt;br&gt;\r\n     * \u30d6\u30e9\u30a6\u30b6\u304c\u8d77\u52d5\u3057\u3001Google\u306e\u8a31\u53ef\u30ea\u30af\u30a8\u30b9\u30c8\u753b\u9762\u304c\u8868\u793a\u3055\u308c\u308b\u3002\r\n     *\r\n     * @param args\r\n     * @throws IOException\r\n     * @throws GeneralSecurityException\r\n     *\/<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"kd\">static<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">main<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span><span class=\"o\">[]<\/span> <span class=\"n\">args<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span><span class=\"o\">,<\/span> <span class=\"nc\">GeneralSecurityException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"nc\">SLF4JBridgeHandler<\/span><span class=\"o\">.<\/span><span class=\"na\">removeHandlersForRootLogger<\/span><span class=\"o\">();<\/span>\r\n        <span class=\"nc\">SLF4JBridgeHandler<\/span><span class=\"o\">.<\/span><span class=\"na\">install<\/span><span class=\"o\">();<\/span>\r\n\r\n        <span class=\"nc\">MyTestApp1<\/span><span class=\"o\">.<\/span><span class=\"na\">getGoogleService<\/span><span class=\"o\">().<\/span><span class=\"na\">authorize<\/span><span class=\"o\">();<\/span>\r\n        <span class=\"no\">LOGGER<\/span><span class=\"o\">.<\/span><span class=\"na\">info<\/span><span class=\"o\">(<\/span><span class=\"s\">\"Credential\u30d5\u30a1\u30a4\u30eb\u3092\u4fdd\u5b58\u3057\u307e\u3057\u305f\u3002\"<\/span><span class=\"o\">);<\/span>\r\n    <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"kn\">package<\/span> <span class=\"nn\">mytestapp1<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.io.IOException<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.io.InputStreamReader<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.io.Reader<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.security.GeneralSecurityException<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.util.Arrays<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.util.List<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.slf4j.Logger<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.slf4j.LoggerFactory<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.slf4j.bridge.SLF4JBridgeHandler<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.drive.DriveScopes<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.drive.model.File<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.sheets.v4.Sheets<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.google.api.services.sheets.v4.SheetsScopes<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"cm\">\/**\r\n * Google\u30b9\u30d7\u30ec\u30c3\u30c9\u30b7\u30fc\u30c8\u3078\u306e\u66f8\u304d\u8fbc\u307f\u3092\u884c\u3046\u3002\r\n *\/<\/span>\r\n<span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">MyTestApp1<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"kd\">final<\/span> <span class=\"nc\">Logger<\/span> <span class=\"no\">LOGGER<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">LoggerFactory<\/span><span class=\"o\">.<\/span><span class=\"na\">getLogger<\/span><span class=\"o\">(<\/span><span class=\"nc\">MyTestApp1<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">);<\/span>\r\n\r\n    <span class=\"c1\">\/\/ Application name.<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"kd\">final<\/span> <span class=\"nc\">String<\/span> <span class=\"no\">APPLICATION_NAME<\/span> <span class=\"o\">=<\/span> <span class=\"s\">\"MyTestApp1\"<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"c1\">\/\/ Return reader for Google client secret.<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"nc\">Reader<\/span> <span class=\"nf\">getClientSecretReader<\/span><span class=\"o\">()<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"k\">new<\/span> <span class=\"nf\">InputStreamReader<\/span><span class=\"o\">(<\/span><span class=\"nc\">MyTestApp1<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">.<\/span><span class=\"na\">getResourceAsStream<\/span><span class=\"o\">(<\/span><span class=\"s\">\"\/google_client_secret.json\"<\/span><span class=\"o\">));<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"c1\">\/\/ Google authorization scopes required by this application.<\/span>\r\n    <span class=\"c1\">\/\/ If modifying these scopes, delete your previously saved credentials.<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"kd\">final<\/span> <span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">String<\/span><span class=\"o\">&gt;<\/span> <span class=\"no\">AUTHORIZATION_SCOPE_LIST<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">Arrays<\/span><span class=\"o\">.<\/span><span class=\"na\">asList<\/span><span class=\"o\">(<\/span><span class=\"nc\">DriveScopes<\/span><span class=\"o\">.<\/span><span class=\"na\">DRIVE<\/span><span class=\"o\">,<\/span> <span class=\"nc\">SheetsScopes<\/span><span class=\"o\">.<\/span><span class=\"na\">SPREADSHEETS<\/span><span class=\"o\">);<\/span>\r\n\r\n    <span class=\"c1\">\/\/ Directory to store Google user credentials for this application.<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"kd\">final<\/span> <span class=\"nc\">String<\/span> <span class=\"no\">CREDENTIAL_STORE_DIRECTORY<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">System<\/span><span class=\"o\">.<\/span><span class=\"na\">getProperty<\/span><span class=\"o\">(<\/span><span class=\"s\">\"user.home\"<\/span><span class=\"o\">)<\/span> <span class=\"o\">+<\/span> <span class=\"s\">\"\/.google_credentials\/\"<\/span> <span class=\"o\">+<\/span> <span class=\"no\">APPLICATION_NAME<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"kd\">static<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">main<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span><span class=\"o\">[]<\/span> <span class=\"n\">args<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">IOException<\/span><span class=\"o\">,<\/span> <span class=\"nc\">GeneralSecurityException<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"nc\">SLF4JBridgeHandler<\/span><span class=\"o\">.<\/span><span class=\"na\">removeHandlersForRootLogger<\/span><span class=\"o\">();<\/span>\r\n        <span class=\"nc\">SLF4JBridgeHandler<\/span><span class=\"o\">.<\/span><span class=\"na\">install<\/span><span class=\"o\">();<\/span>\r\n\r\n        <span class=\"kd\">final<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">folderName<\/span> <span class=\"o\">=<\/span> <span class=\"s\">\"\u30d5\u30a9\u30eb\u30c01\"<\/span><span class=\"o\">;<\/span>\r\n        <span class=\"kd\">final<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">spreadsheetName<\/span> <span class=\"o\">=<\/span> <span class=\"s\">\"\u30b9\u30d7\u30ec\u30c3\u30c9\u30b7\u30fc\u30c81\"<\/span><span class=\"o\">;<\/span>\r\n        <span class=\"kd\">final<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">worksheetName<\/span> <span class=\"o\">=<\/span> <span class=\"s\">\"\u30ef\u30fc\u30af\u30b7\u30fc\u30c81\"<\/span><span class=\"o\">;<\/span>\r\n\r\n        <span class=\"c1\">\/\/ Build a new authorized API client service.<\/span>\r\n        <span class=\"nc\">GoogleService<\/span> <span class=\"n\">googleService<\/span> <span class=\"o\">=<\/span> <span class=\"n\">getGoogleService<\/span><span class=\"o\">();<\/span>\r\n        <span class=\"nc\">SheetsWrapper<\/span> <span class=\"n\">sheetsWrapper<\/span> <span class=\"o\">=<\/span> <span class=\"n\">googleService<\/span><span class=\"o\">.<\/span><span class=\"na\">getSheetsWrapperWithWorksheet<\/span><span class=\"o\">(<\/span><span class=\"n\">folderName<\/span><span class=\"o\">,<\/span> <span class=\"n\">spreadsheetName<\/span><span class=\"o\">,<\/span> <span class=\"n\">worksheetName<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"kt\">int<\/span> <span class=\"n\">lastRowNumberWithValue<\/span> <span class=\"o\">=<\/span> <span class=\"n\">sheetsWrapper<\/span><span class=\"o\">.<\/span><span class=\"na\">getLastRowNumberWithValue<\/span><span class=\"o\">(<\/span><span class=\"n\">worksheetName<\/span><span class=\"o\">,<\/span> <span class=\"mi\">1<\/span><span class=\"o\">);<\/span>\r\n\r\n        <span class=\"c1\">\/\/ \u5024\u306e\u5165\u3063\u3066\u3044\u308b\u6700\u5f8c\u306e\u884c\u306e\u6b21\u306e\u884c\u304b\u3089\u66f8\u304d\u8fbc\u307f<\/span>\r\n        <span class=\"nc\">Object<\/span><span class=\"o\">[][]<\/span> <span class=\"n\">values<\/span> <span class=\"o\">=<\/span> <span class=\"o\">{<\/span> <span class=\"o\">{<\/span> <span class=\"mi\">1<\/span><span class=\"o\">,<\/span> <span class=\"s\">\"A\"<\/span> <span class=\"o\">},<\/span> <span class=\"o\">{<\/span> <span class=\"mf\">2.1<\/span><span class=\"no\">D<\/span><span class=\"o\">,<\/span> <span class=\"s\">\"B\"<\/span> <span class=\"o\">},<\/span> <span class=\"o\">{<\/span> <span class=\"mf\">2.50<\/span><span class=\"no\">E<\/span><span class=\"o\">-<\/span><span class=\"mi\">3<\/span><span class=\"o\">,<\/span> <span class=\"s\">\"C\"<\/span> <span class=\"o\">}<\/span> <span class=\"o\">};<\/span>\r\n        <span class=\"n\">sheetsWrapper<\/span><span class=\"o\">.<\/span><span class=\"na\">setValues<\/span><span class=\"o\">(<\/span><span class=\"n\">worksheetName<\/span><span class=\"o\">,<\/span> <span class=\"mi\">1<\/span><span class=\"o\">,<\/span> <span class=\"n\">lastRowNumWithValue<\/span> <span class=\"o\">+<\/span> <span class=\"mi\">1<\/span><span class=\"o\">,<\/span> <span class=\"n\">values<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"no\">LOGGER<\/span><span class=\"o\">.<\/span><span class=\"na\">info<\/span><span class=\"o\">(<\/span><span class=\"s\">\"\u66f8\u304d\u8fbc\u307f\u307e\u3057\u305f\u3002\"<\/span><span class=\"o\">);<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"kd\">static<\/span> <span class=\"nc\">GoogleService<\/span> <span class=\"nf\">getGoogleService<\/span><span class=\"o\">()<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"k\">new<\/span> <span class=\"nf\">GoogleService<\/span><span class=\"o\">(<\/span><span class=\"n\">getClientSecretReader<\/span><span class=\"o\">(),<\/span> <span class=\"no\">AUTHORIZATION_SCOPE_LIST<\/span><span class=\"o\">,<\/span> <span class=\"no\">CREDENTIAL_STORE_DIRECTORY<\/span><span class=\"o\">,<\/span> <span class=\"no\">APPLICATION_NAME<\/span><span class=\"o\">);<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"nc\">Reader<\/span> <span class=\"nf\">getClientSecretReader<\/span><span class=\"o\">()<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"k\">new<\/span> <span class=\"nf\">InputStreamReader<\/span><span class=\"o\">(<\/span><span class=\"nc\">MyTestApp1<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">.<\/span><span class=\"na\">getResourceAsStream<\/span><span class=\"o\">(<\/span><span class=\"s\">\"\/google_client_secret.json\"<\/span><span class=\"o\">));<\/span>\r\n    <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"cp\">&lt;?xml version=\"1.0\" encoding=\"UTF-8\"?&gt;<\/span>\r\n<span class=\"cp\">&lt;!DOCTYPE logback&gt;<\/span>\r\n<span class=\"nt\">&lt;configuration&gt;<\/span>\r\n    <span class=\"nt\">&lt;contextListener<\/span> <span class=\"na\">class=<\/span><span class=\"s\">\"ch.qos.logback.classic.jul.LevelChangePropagator\"<\/span><span class=\"nt\">&gt;<\/span>\r\n        <span class=\"nt\">&lt;resetJUL&gt;<\/span>true<span class=\"nt\">&lt;\/resetJUL&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/contextListener&gt;<\/span>\r\n    <span class=\"nt\">&lt;appender<\/span> <span class=\"na\">name=<\/span><span class=\"s\">\"STDOUT\"<\/span> <span class=\"na\">class=<\/span><span class=\"s\">\"ch.qos.logback.core.ConsoleAppender\"<\/span><span class=\"nt\">&gt;<\/span>\r\n        <span class=\"nt\">&lt;encoder&gt;<\/span>\r\n            <span class=\"nt\">&lt;pattern&gt;<\/span>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n<span class=\"nt\">&lt;\/pattern&gt;<\/span>\r\n        <span class=\"nt\">&lt;\/encoder&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/appender&gt;<\/span>\r\n    <span class=\"nt\">&lt;root<\/span> <span class=\"na\">level=<\/span><span class=\"s\">\"INFO\"<\/span><span class=\"nt\">&gt;<\/span>\r\n        <span class=\"nt\">&lt;appender-ref<\/span> <span class=\"na\">ref=<\/span><span class=\"s\">\"STDOUT\"<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/root&gt;<\/span>\r\n<span class=\"nt\">&lt;\/configuration&gt;<\/span>\r\n<\/code><\/pre>\n<h2>3. \u6267\u884c<br \/>\n\u5f53\u6267\u884cCreateCredentialFile\u7c7b\u65f6\uff0c\u4f1a\u542f\u52a8\u6d4f\u89c8\u5668\u5e76\u663e\u793a\u4ee5\u4e0b\u754c\u9762<br \/>\n\uff08\u6700\u597d\u51c6\u5907\u597d\u5df2\u767b\u5f55Google\u7684\u6d4f\u89c8\u5668\uff09<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d0b9337434c4406be68dc\/21-0.jpeg\" alt=\"18.jpg\" \/>\u6309\u4e0b\u300c\u5141\u8bb8\u300d\u540e\uff0c\u5c06\u663e\u793a\u4ee5\u4e0b\u5c4f\u5e55\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d0b9337434c4406be68dc\/23-0.jpeg\" alt=\"19.jpg\" \/>\u5f53\u6267\u884cMyTestApp1\u7c7b\u65f6\uff0c\u4f1a\u8fdb\u884c\u5199\u5165\u64cd\u4f5c\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>http:\/\/qiita.com\/pilot\/items\/85bae4e5d5e35ffa7019 \u7684\u540e\u7eed\u5185\u5bb9 [&hellip;]<\/p>\n","protected":false},"author":11,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[227],"class_list":["post-31222","post","type-post","status-publish","format-standard","hentry","category-uncategorized","tag-227"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u7528Java\u5c06\u6570\u636e\u5199\u5165Google Spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08Java\u7aef\uff09 - Blog - Silicon Cloud<\/title>\n<meta name=\"description\" content=\"\u5173\u4e8e\u7528Java\u5c06\u6570\u636e\u5199\u5165Google Spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08Java\u7aef\uff09\u7684\u6280\u672f\u6587\u7ae0\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u7528java\u5c06\u6570\u636e\u5199\u5165google-spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08java\u7aef\uff09\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u7528Java\u5c06\u6570\u636e\u5199\u5165Google Spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08Java\u7aef\uff09\" \/>\n<meta property=\"og:description\" content=\"\u5173\u4e8e\u7528Java\u5c06\u6570\u636e\u5199\u5165Google Spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08Java\u7aef\uff09\u7684\u6280\u672f\u6587\u7ae0\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u7528java\u5c06\u6570\u636e\u5199\u5165google-spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08java\u7aef\uff09\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-03-18T01:50:36+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-08-12T14:55:19+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d0b9337434c4406be68dc\/21-0.jpeg\" \/>\n<meta name=\"author\" content=\"\u65b0, \u97f5\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u65b0, \u97f5\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"1 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e7%94%a8java%e5%b0%86%e6%95%b0%e6%8d%ae%e5%86%99%e5%85%a5google-spreadsheet%e7%ac%ac%e4%ba%8c%e9%83%a8%e5%88%86%ef%bc%88java%e7%ab%af%ef%bc%89\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e7%94%a8java%e5%b0%86%e6%95%b0%e6%8d%ae%e5%86%99%e5%85%a5google-spreadsheet%e7%ac%ac%e4%ba%8c%e9%83%a8%e5%88%86%ef%bc%88java%e7%ab%af%ef%bc%89\/\",\"name\":\"\u7528Java\u5c06\u6570\u636e\u5199\u5165Google Spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08Java\u7aef\uff09 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-03-18T01:50:36+00:00\",\"dateModified\":\"2025-08-12T14:55:19+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/4ba4019495123db3038fd0809e6959c9\"},\"description\":\"\u5173\u4e8e\u7528Java\u5c06\u6570\u636e\u5199\u5165Google Spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08Java\u7aef\uff09\u7684\u6280\u672f\u6587\u7ae0\",\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e7%94%a8java%e5%b0%86%e6%95%b0%e6%8d%ae%e5%86%99%e5%85%a5google-spreadsheet%e7%ac%ac%e4%ba%8c%e9%83%a8%e5%88%86%ef%bc%88java%e7%ab%af%ef%bc%89\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e7%94%a8java%e5%b0%86%e6%95%b0%e6%8d%ae%e5%86%99%e5%85%a5google-spreadsheet%e7%ac%ac%e4%ba%8c%e9%83%a8%e5%88%86%ef%bc%88java%e7%ab%af%ef%bc%89\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e7%94%a8java%e5%b0%86%e6%95%b0%e6%8d%ae%e5%86%99%e5%85%a5google-spreadsheet%e7%ac%ac%e4%ba%8c%e9%83%a8%e5%88%86%ef%bc%88java%e7%ab%af%ef%bc%89\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u7528Java\u5c06\u6570\u636e\u5199\u5165Google Spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08Java\u7aef\uff09\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/4ba4019495123db3038fd0809e6959c9\",\"name\":\"\u65b0, \u97f5\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g\",\"caption\":\"\u65b0, \u97f5\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/yunxin\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e7%94%a8java%e5%b0%86%e6%95%b0%e6%8d%ae%e5%86%99%e5%85%a5google-spreadsheet%e7%ac%ac%e4%ba%8c%e9%83%a8%e5%88%86%ef%bc%88java%e7%ab%af%ef%bc%89\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u7528Java\u5c06\u6570\u636e\u5199\u5165Google Spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08Java\u7aef\uff09 - Blog - Silicon Cloud","description":"\u5173\u4e8e\u7528Java\u5c06\u6570\u636e\u5199\u5165Google Spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08Java\u7aef\uff09\u7684\u6280\u672f\u6587\u7ae0","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u7528java\u5c06\u6570\u636e\u5199\u5165google-spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08java\u7aef\uff09\/","og_locale":"zh_CN","og_type":"article","og_title":"\u7528Java\u5c06\u6570\u636e\u5199\u5165Google Spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08Java\u7aef\uff09","og_description":"\u5173\u4e8e\u7528Java\u5c06\u6570\u636e\u5199\u5165Google Spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08Java\u7aef\uff09\u7684\u6280\u672f\u6587\u7ae0","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u7528java\u5c06\u6570\u636e\u5199\u5165google-spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08java\u7aef\uff09\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-03-18T01:50:36+00:00","article_modified_time":"2025-08-12T14:55:19+00:00","og_image":[{"url":"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d0b9337434c4406be68dc\/21-0.jpeg"}],"author":"\u65b0, \u97f5","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u65b0, \u97f5","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"1 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e7%94%a8java%e5%b0%86%e6%95%b0%e6%8d%ae%e5%86%99%e5%85%a5google-spreadsheet%e7%ac%ac%e4%ba%8c%e9%83%a8%e5%88%86%ef%bc%88java%e7%ab%af%ef%bc%89\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e7%94%a8java%e5%b0%86%e6%95%b0%e6%8d%ae%e5%86%99%e5%85%a5google-spreadsheet%e7%ac%ac%e4%ba%8c%e9%83%a8%e5%88%86%ef%bc%88java%e7%ab%af%ef%bc%89\/","name":"\u7528Java\u5c06\u6570\u636e\u5199\u5165Google Spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08Java\u7aef\uff09 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-03-18T01:50:36+00:00","dateModified":"2025-08-12T14:55:19+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/4ba4019495123db3038fd0809e6959c9"},"description":"\u5173\u4e8e\u7528Java\u5c06\u6570\u636e\u5199\u5165Google Spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08Java\u7aef\uff09\u7684\u6280\u672f\u6587\u7ae0","breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e7%94%a8java%e5%b0%86%e6%95%b0%e6%8d%ae%e5%86%99%e5%85%a5google-spreadsheet%e7%ac%ac%e4%ba%8c%e9%83%a8%e5%88%86%ef%bc%88java%e7%ab%af%ef%bc%89\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e7%94%a8java%e5%b0%86%e6%95%b0%e6%8d%ae%e5%86%99%e5%85%a5google-spreadsheet%e7%ac%ac%e4%ba%8c%e9%83%a8%e5%88%86%ef%bc%88java%e7%ab%af%ef%bc%89\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e7%94%a8java%e5%b0%86%e6%95%b0%e6%8d%ae%e5%86%99%e5%85%a5google-spreadsheet%e7%ac%ac%e4%ba%8c%e9%83%a8%e5%88%86%ef%bc%88java%e7%ab%af%ef%bc%89\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u7528Java\u5c06\u6570\u636e\u5199\u5165Google Spreadsheet\u7b2c\u4e8c\u90e8\u5206\uff08Java\u7aef\uff09"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/4ba4019495123db3038fd0809e6959c9","name":"\u65b0, \u97f5","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g","caption":"\u65b0, \u97f5"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/yunxin\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e7%94%a8java%e5%b0%86%e6%95%b0%e6%8d%ae%e5%86%99%e5%85%a5google-spreadsheet%e7%ac%ac%e4%ba%8c%e9%83%a8%e5%88%86%ef%bc%88java%e7%ab%af%ef%bc%89\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/31222","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/11"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=31222"}],"version-history":[{"count":3,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/31222\/revisions"}],"predecessor-version":[{"id":111897,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/31222\/revisions\/111897"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=31222"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=31222"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=31222"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}