2009-11-25 135 views
1

我想使用SpreadsheetEntry继承的BaseEntry类的[generateAtom(..,..)] [1]方法获取GoogleDocs电子表格的原子格式的XML。但我不明白方法中的第二个参数ExtensionProfile。这是什么,如果我只想以原子格式获取XML,这个方法就足够了吗?什么是GDATA扩展配置文件?

XmlWriter x = new XmlWriter(); 
spreadSheetEntry.generateAtom(x,new ExtensionProfile()); 

[1]:http://code.google.com/apis/gdata/javadoc/com/google/gdata/data/BaseEntry.html#generateAtom(com.google.gdata.util.common.xml.XmlWriter,com.google.gdata.data.ExtensionProfile)

回答

0

阐述Jon Skeet's answer,你需要实例化一个像这样的服务:

String developer_key = "mySecretDeveloperKey"; 
String client_id = "myApplicationsClientId"; 
YouTubeService service = new YouTubeService(client_id, developer_key); 

然后你可以使用你的服务的扩展配置文件写入文件:

static void write_video_entry(VideoEntry video_entry) { 
    try { 
     String cache_file_path = Layout.get_cache_file_path(video_entry); 
     File cache_file = new File(cache_file_path); 
     Writer writer = new FileWriter(cache_file); 
     XmlWriter xml_writer = new XmlWriter(writer); 
     ExtensionProfile extension_profile = service.getExtensionProfile(); 
     video_entry.generateAtom(xml_writer, extension_profile); 
     xml_writer.close(); 
     writer.close(); 
    } catch (IOException e) { 
     e.printStackTrace(); 
    } 
} 

类似,你可以阅读使用您的服务的扩展档案的文件:

static VideoFeed read_video_feed(File cache_file_file) { 
    VideoFeed video_feed = new VideoFeed(); 
    try { 
     InputStream input_stream = new FileInputStream(cache_file_file); 
     ExtensionProfile extension_profile = service.getExtensionProfile(); 
     try { 
      video_feed.parseAtom(extension_profile, input_stream); 
     } catch (ParseException e) { 
      e.printStackTrace(); 
     } 
     input_stream.close(); 
    } catch (IOException e) { 
     e.printStackTrace(); 
    } 
    return video_feed; 
}