Skip to content

Instantly share code, notes, and snippets.

@jennybc
Last active May 13, 2016 16:43
Show Gist options
  • Save jennybc/37398c989852aa0c7abd9c5cea75e4f6 to your computer and use it in GitHub Desktop.
Save jennybc/37398c989852aa0c7abd9c5cea75e4f6 to your computer and use it in GitHub Desktop.
27_test-drive-new-xml2
<feed xmlns="http://www.w3.org/2005/Atom" xmlns:batch="http://schemas.google.com/gdata/batch" xmlns:gs="http://schemas.google.com/spreadsheets/2006">
<id>SOME_URL</id>
<entry>
<batch:id>A1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C1/fu9n6e"/>
<gs:cell row="1" col="1" inputValue="country"/>
</entry>
<entry>
<batch:id>B1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C2/skdkms"/>
<gs:cell row="1" col="2" inputValue="continent"/>
</entry>
<entry>
<batch:id>C1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C3/m6lh9"/>
<gs:cell row="1" col="3" inputValue="year"/>
</entry>
<entry>
<batch:id>D1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C4/2ix4zl"/>
<gs:cell row="1" col="4" inputValue="lifeExp"/>
</entry>
<entry>
<batch:id>E1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C5/140rbl"/>
<gs:cell row="1" col="5" inputValue="pop"/>
</entry>
<entry>
<batch:id>F1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C6/ttswx4"/>
<gs:cell row="1" col="6" inputValue="gdpPercap"/>
</entry>
<entry>
<batch:id>A2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C1/cdj6rl"/>
<gs:cell row="2" col="1" inputValue="Algeria"/>
</entry>
<entry>
<batch:id>B2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C2/wo1nru"/>
<gs:cell row="2" col="2" inputValue="Africa"/>
</entry>
<entry>
<batch:id>C2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C3/kua4l"/>
<gs:cell row="2" col="3" inputValue="1952"/>
</entry>
<entry>
<batch:id>D2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C4/olavj5"/>
<gs:cell row="2" col="4" inputValue="43.077"/>
</entry>
<entry>
<batch:id>E2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C5/7ot21p"/>
<gs:cell row="2" col="5" inputValue="9279525"/>
</entry>
<entry>
<batch:id>F2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C6/emxr9d"/>
<gs:cell row="2" col="6" inputValue="2449.0082"/>
</entry>
<entry>
<batch:id>A3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C1/widqne"/>
<gs:cell row="3" col="1" inputValue="Angola"/>
</entry>
<entry>
<batch:id>B3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C2/wo5vh6"/>
<gs:cell row="3" col="2" inputValue="Africa"/>
</entry>
<entry>
<batch:id>C3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C3/ksvk5"/>
<gs:cell row="3" col="3" inputValue="1952"/>
</entry>
<entry>
<batch:id>D3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C4/p6lnb7"/>
<gs:cell row="3" col="4" inputValue="30.015"/>
</entry>
<entry>
<batch:id>E3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C5/59q5sf"/>
<gs:cell row="3" col="5" inputValue="4232095"/>
</entry>
<entry>
<batch:id>F3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C6/dsxy4s"/>
<gs:cell row="3" col="6" inputValue="3520.6103"/>
</entry>
<entry>
<batch:id>A4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C1/126nkg"/>
<gs:cell row="4" col="1" inputValue="Benin"/>
</entry>
<entry>
<batch:id>B4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C2/wo4gwq"/>
<gs:cell row="4" col="2" inputValue="Africa"/>
</entry>
<entry>
<batch:id>C4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C3/krgzp"/>
<gs:cell row="4" col="3" inputValue="1952"/>
</entry>
<entry>
<batch:id>D4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C4/oqzg8a"/>
<gs:cell row="4" col="4" inputValue="38.223"/>
</entry>
<entry>
<batch:id>E4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C5/1cdhnw"/>
<gs:cell row="4" col="5" inputValue="1738315"/>
</entry>
<entry>
<batch:id>F4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C6/qb9pxt"/>
<gs:cell row="4" col="6" inputValue="1062.7522"/>
</entry>
<entry>
<batch:id>A5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C1/17iysp"/>
<gs:cell row="5" col="1" inputValue="Botswana"/>
</entry>
<entry>
<batch:id>B5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C2/wnxg2i"/>
<gs:cell row="5" col="2" inputValue="Africa"/>
</entry>
<entry>
<batch:id>C5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C3/kq2f9"/>
<gs:cell row="5" col="3" inputValue="1952"/>
</entry>
<entry>
<batch:id>D5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C4/onmdxn"/>
<gs:cell row="5" col="4" inputValue="47.622"/>
</entry>
<entry>
<batch:id>E5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C5/qjynih"/>
<gs:cell row="5" col="5" inputValue="442308"/>
</entry>
<entry>
<batch:id>F5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C6/1pp67w"/>
<gs:cell row="5" col="6" inputValue="851.2411"/>
</entry>
<entry>
<batch:id>A6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C1/jsdcfb"/>
<gs:cell row="6" col="1" inputValue="Burkina Faso"/>
</entry>
<entry>
<batch:id>B6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C2/wnw1i2"/>
<gs:cell row="6" col="2" inputValue="Africa"/>
</entry>
<entry>
<batch:id>C6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C3/konut"/>
<gs:cell row="6" col="3" inputValue="1952"/>
</entry>
<entry>
<batch:id>D6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C4/p6vsqv"/>
<gs:cell row="6" col="4" inputValue="31.975"/>
</entry>
<entry>
<batch:id>E6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C5/8hjliw"/>
<gs:cell row="6" col="5" inputValue="4469979"/>
</entry>
<entry>
<batch:id>F6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C6/8m4llm"/>
<gs:cell row="6" col="6" inputValue="543.2552"/>
</entry>
</feed>
<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xmlns:batch="http://schemas.google.com/gdata/batch" xmlns:gs="http://schemas.google.com/spreadsheets/2006">
<id>SOME_URL</id>
<entry>
<batch:id>A1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C1/fu9n6e"/>
<gs:cell row="1" col="1" inputValue="country"/>
</entry>
<entry>
<batch:id>B1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C2/skdkms"/>
<gs:cell row="1" col="2" inputValue="continent"/>
</entry>
<entry>
<batch:id>C1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C3/m6lh9"/>
<gs:cell row="1" col="3" inputValue="year"/>
</entry>
<entry>
<batch:id>D1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C4/2ix4zl"/>
<gs:cell row="1" col="4" inputValue="lifeExp"/>
</entry>
<entry>
<batch:id>E1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C5/140rbl"/>
<gs:cell row="1" col="5" inputValue="pop"/>
</entry>
<entry>
<batch:id>F1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C6/ttswx4"/>
<gs:cell row="1" col="6" inputValue="gdpPercap"/>
</entry>
<entry>
<batch:id>A2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C1/cdj6rl"/>
<gs:cell row="2" col="1" inputValue="Algeria"/>
</entry>
<entry>
<batch:id>B2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C2/wo1nru"/>
<gs:cell row="2" col="2" inputValue="Africa"/>
</entry>
<entry>
<batch:id>C2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C3/kua4l"/>
<gs:cell row="2" col="3" inputValue="1952"/>
</entry>
<entry>
<batch:id>D2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C4/olavj5"/>
<gs:cell row="2" col="4" inputValue="43.077"/>
</entry>
<entry>
<batch:id>E2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C5/7ot21p"/>
<gs:cell row="2" col="5" inputValue="9279525"/>
</entry>
<entry>
<batch:id>F2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C6/emxr9d"/>
<gs:cell row="2" col="6" inputValue="2449.0082"/>
</entry>
<entry>
<batch:id>A3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C1/widqne"/>
<gs:cell row="3" col="1" inputValue="Angola"/>
</entry>
<entry>
<batch:id>B3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C2/wo5vh6"/>
<gs:cell row="3" col="2" inputValue="Africa"/>
</entry>
<entry>
<batch:id>C3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C3/ksvk5"/>
<gs:cell row="3" col="3" inputValue="1952"/>
</entry>
<entry>
<batch:id>D3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C4/p6lnb7"/>
<gs:cell row="3" col="4" inputValue="30.015"/>
</entry>
<entry>
<batch:id>E3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C5/59q5sf"/>
<gs:cell row="3" col="5" inputValue="4232095"/>
</entry>
<entry>
<batch:id>F3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C6/dsxy4s"/>
<gs:cell row="3" col="6" inputValue="3520.6103"/>
</entry>
<entry>
<batch:id>A4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C1/126nkg"/>
<gs:cell row="4" col="1" inputValue="Benin"/>
</entry>
<entry>
<batch:id>B4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C2/wo4gwq"/>
<gs:cell row="4" col="2" inputValue="Africa"/>
</entry>
<entry>
<batch:id>C4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C3/krgzp"/>
<gs:cell row="4" col="3" inputValue="1952"/>
</entry>
<entry>
<batch:id>D4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C4/oqzg8a"/>
<gs:cell row="4" col="4" inputValue="38.223"/>
</entry>
<entry>
<batch:id>E4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C5/1cdhnw"/>
<gs:cell row="4" col="5" inputValue="1738315"/>
</entry>
<entry>
<batch:id>F4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C6/qb9pxt"/>
<gs:cell row="4" col="6" inputValue="1062.7522"/>
</entry>
<entry>
<batch:id>A5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C1/17iysp"/>
<gs:cell row="5" col="1" inputValue="Botswana"/>
</entry>
<entry>
<batch:id>B5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C2/wnxg2i"/>
<gs:cell row="5" col="2" inputValue="Africa"/>
</entry>
<entry>
<batch:id>C5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C3/kq2f9"/>
<gs:cell row="5" col="3" inputValue="1952"/>
</entry>
<entry>
<batch:id>D5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C4/onmdxn"/>
<gs:cell row="5" col="4" inputValue="47.622"/>
</entry>
<entry>
<batch:id>E5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C5/qjynih"/>
<gs:cell row="5" col="5" inputValue="442308"/>
</entry>
<entry>
<batch:id>F5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C6/1pp67w"/>
<gs:cell row="5" col="6" inputValue="851.2411"/>
</entry>
<entry>
<batch:id>A6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C1/jsdcfb"/>
<gs:cell row="6" col="1" inputValue="Burkina Faso"/>
</entry>
<entry>
<batch:id>B6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C2/wnw1i2"/>
<gs:cell row="6" col="2" inputValue="Africa"/>
</entry>
<entry>
<batch:id>C6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C3/konut"/>
<gs:cell row="6" col="3" inputValue="1952"/>
</entry>
<entry>
<batch:id>D6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C4/p6vsqv"/>
<gs:cell row="6" col="4" inputValue="31.975"/>
</entry>
<entry>
<batch:id>E6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C5/8hjliw"/>
<gs:cell row="6" col="5" inputValue="4469979"/>
</entry>
<entry>
<batch:id>F6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C6/8m4llm"/>
<gs:cell row="6" col="6" inputValue="543.2552"/>
</entry>
</feed>
<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xmlns:batch="http://schemas.google.com/gdata/batch" xmlns:gs="http://schemas.google.com/spreadsheets/2006">
<id>SOME_URL</id>
<entry>
<batch:id>A1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C1/fu9n6e"/>
<gs:cell row="1" col="1" inputValue="country"/>
</entry>
<entry>
<batch:id>B1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C2/skdkms"/>
<gs:cell row="1" col="2" inputValue="continent"/>
</entry>
<entry>
<batch:id>C1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C3/m6lh9"/>
<gs:cell row="1" col="3" inputValue="year"/>
</entry>
<entry>
<batch:id>D1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C4/2ix4zl"/>
<gs:cell row="1" col="4" inputValue="lifeExp"/>
</entry>
<entry>
<batch:id>E1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C5/140rbl"/>
<gs:cell row="1" col="5" inputValue="pop"/>
</entry>
<entry>
<batch:id>F1</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C6/ttswx4"/>
<gs:cell row="1" col="6" inputValue="gdpPercap"/>
</entry>
<entry>
<batch:id>A2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C1/cdj6rl"/>
<gs:cell row="2" col="1" inputValue="Algeria"/>
</entry>
<entry>
<batch:id>B2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C2/wo1nru"/>
<gs:cell row="2" col="2" inputValue="Africa"/>
</entry>
<entry>
<batch:id>C2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C3/kua4l"/>
<gs:cell row="2" col="3" inputValue="1952"/>
</entry>
<entry>
<batch:id>D2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C4/olavj5"/>
<gs:cell row="2" col="4" inputValue="43.077"/>
</entry>
<entry>
<batch:id>E2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C5/7ot21p"/>
<gs:cell row="2" col="5" inputValue="9279525"/>
</entry>
<entry>
<batch:id>F2</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C6/emxr9d"/>
<gs:cell row="2" col="6" inputValue="2449.0082"/>
</entry>
<entry>
<batch:id>A3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C1/widqne"/>
<gs:cell row="3" col="1" inputValue="Angola"/>
</entry>
<entry>
<batch:id>B3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C2/wo5vh6"/>
<gs:cell row="3" col="2" inputValue="Africa"/>
</entry>
<entry>
<batch:id>C3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C3/ksvk5"/>
<gs:cell row="3" col="3" inputValue="1952"/>
</entry>
<entry>
<batch:id>D3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C4/p6lnb7"/>
<gs:cell row="3" col="4" inputValue="30.015"/>
</entry>
<entry>
<batch:id>E3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C5/59q5sf"/>
<gs:cell row="3" col="5" inputValue="4232095"/>
</entry>
<entry>
<batch:id>F3</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C6/dsxy4s"/>
<gs:cell row="3" col="6" inputValue="3520.6103"/>
</entry>
<entry>
<batch:id>A4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C1/126nkg"/>
<gs:cell row="4" col="1" inputValue="Benin"/>
</entry>
<entry>
<batch:id>B4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C2/wo4gwq"/>
<gs:cell row="4" col="2" inputValue="Africa"/>
</entry>
<entry>
<batch:id>C4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C3/krgzp"/>
<gs:cell row="4" col="3" inputValue="1952"/>
</entry>
<entry>
<batch:id>D4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C4/oqzg8a"/>
<gs:cell row="4" col="4" inputValue="38.223"/>
</entry>
<entry>
<batch:id>E4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C5/1cdhnw"/>
<gs:cell row="4" col="5" inputValue="1738315"/>
</entry>
<entry>
<batch:id>F4</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C6/qb9pxt"/>
<gs:cell row="4" col="6" inputValue="1062.7522"/>
</entry>
<entry>
<batch:id>A5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C1/17iysp"/>
<gs:cell row="5" col="1" inputValue="Botswana"/>
</entry>
<entry>
<batch:id>B5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C2/wnxg2i"/>
<gs:cell row="5" col="2" inputValue="Africa"/>
</entry>
<entry>
<batch:id>C5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C3/kq2f9"/>
<gs:cell row="5" col="3" inputValue="1952"/>
</entry>
<entry>
<batch:id>D5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C4/onmdxn"/>
<gs:cell row="5" col="4" inputValue="47.622"/>
</entry>
<entry>
<batch:id>E5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C5/qjynih"/>
<gs:cell row="5" col="5" inputValue="442308"/>
</entry>
<entry>
<batch:id>F5</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C6/1pp67w"/>
<gs:cell row="5" col="6" inputValue="851.2411"/>
</entry>
<entry>
<batch:id>A6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C1</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C1/jsdcfb"/>
<gs:cell row="6" col="1" inputValue="Burkina Faso"/>
</entry>
<entry>
<batch:id>B6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C2</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C2/wnw1i2"/>
<gs:cell row="6" col="2" inputValue="Africa"/>
</entry>
<entry>
<batch:id>C6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C3</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C3/konut"/>
<gs:cell row="6" col="3" inputValue="1952"/>
</entry>
<entry>
<batch:id>D6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C4</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C4/p6vsqv"/>
<gs:cell row="6" col="4" inputValue="31.975"/>
</entry>
<entry>
<batch:id>E6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C5</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C5/8hjliw"/>
<gs:cell row="6" col="5" inputValue="4469979"/>
</entry>
<entry>
<batch:id>F6</batch:id>
<batch:operation type="update"/>
<id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C6</id>
<link rel="edit" type="application/atom+xml" href="https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C6/8m4llm"/>
<gs:cell row="6" col="6" inputValue="543.2552"/>
</entry>
</feed>

27_test-drive-new-xml2.R

jenny Fri May 13 09:40:57 2016

Task: create XML to update contents of cells in a Google Sheet.

Here's how I currently do it with the XML package.

library(readr)
library(XML)
#> Warning: package 'XML' was built under R version 3.2.4
library(purrr)

update_fodder <- read_csv("27_update-fodder.csv")
africa_cellsfeed <- "SOME_URL"

f_XML <- function(cell, cell_id, edit_link, row, col, update_value) {
  XML::xmlNode("entry",
               XML::xmlNode("batch:id", cell),
               XML::xmlNode("batch:operation",
                            attrs = c("type" = "update")),
               XML::xmlNode("id", cell_id),
               XML::xmlNode("link",
                            attrs = c("rel" = "edit",
                                      "type" = "application/atom+xml",
                                      "href" = edit_link)),
               XML::xmlNode("gs:cell",
                            attrs = c("row" = row,
                                      "col" = col,
                                      "inputValue" = update_value)))
}

list_of_nodes <- update_fodder %>%
  pmap(f_XML)
feed_node <-
  xmlNode("feed",
          namespaceDefinitions =
            c("http://www.w3.org/2005/Atom",
              batch = "http://schemas.google.com/gdata/batch",
              gs = "http://schemas.google.com/spreadsheets/2006"),
          .children = list(xmlNode("id", africa_cellsfeed))) %>%
  addChildren(kids = list_of_nodes)
## here's what I actually send as body of an httr::POST request:
write(toString.XMLNode(feed_node), "27_feed-node-XML.xml")

Installing / verifying xml2 from the relevant PR.

#devtools::install_github("hadley/xml2#76")
si <- devtools::session_info("xml2")$packages
si$source[si$package == "xml2"]
#> [1] "Github (jimhester/xml2@63e5c1c)"

Current approach given by @jimhester.

library(xml2)
d <- xml_new_document() %>%
  xml_add_child("feed",
                xmlns = "http://www.w3.org/2005/Atom",
                "xmlns:batch" = "http://schemas.google.com/gdata/batch",
                "xmlns:gs" = "http://schemas.google.com/spreadsheets/2006")

d %>% xml_add_child("id", africa_cellsfeed)
#> {xml_node}
#> <id>
f_XML <- function(cell, cell_id, edit_link, row, col, update_value) {
  d %>%
    xml_add_child("entry") %>%
    xml_add_child("batch:id", cell) %>%
    xml_add_sibling("batch:operation", type = "update") %>%
    xml_add_sibling("id", cell_id) %>%
    xml_add_sibling("link", rel = "edit", type = "application/atom+xml",
                    href = edit_link) %>%
    xml_add_sibling("gs:cell", row = as.character(row), col = as.character(col),
                    inputValue = update_value)
}

update_fodder %>% pwalk(f_XML)

write_xml(d, "27_feed-node-xml2.xml")

How does this compare to the output from the XML package? xml2 adds an XML declaration.

diff -b -U 0 27_feed-node-XML.xml 27_feed-node-xml2.xml
#> --- 27_feed-node-XML.xml 2016-05-13 09:40:58.000000000 -0700
#> +++ 27_feed-node-xml2.xml    2016-05-13 09:40:58.000000000 -0700
#> @@ -0,0 +1 @@
#> +<?xml version="1.0"?>

Can xml2 roundtrip it's own XML? I.e. the new linebreaks don't cause trouble? I wonder because of r-lib/xml2#49.

rt <- read_xml("27_feed-node-xml2.xml")
identical(as_list(d), as_list(rt))
#> [1] FALSE
head(all.equal(as_list(d), as_list(rt)))
#> [1] "Names: 20 string mismatches"                                   
#> [2] "Length mismatch: comparison on first 37 components"            
#> [3] "Component 1: Modes: list, character"                           
#> [4] "Component 1: Component 1: 1 string mismatch"                   
#> [5] "Component 2: names for target but not for current"             
#> [6] "Component 2: Length mismatch: comparison on first 1 components"
xml_children(d)[[2]]
#> {xml_node}
#> <entry>
#> [1] <batch:id>A1</batch:id>
#> [2] <batch:operation type="update"/>
#> [3] <id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL ...
#> [4] <link rel="edit" type="application/atom+xml" href="https://spreadshe ...
#> [5] <gs:cell row="1" col="1" inputValue="country"/>
xml_children(rt)[[2]]
#> {xml_node}
#> <entry>
#> [1] <batch:id>A1</batch:id>
#> [2] <batch:operation type="update"/>
#> [3] <id>https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL ...
#> [4] <link rel="edit" type="application/atom+xml" href="https://spreadshe ...
#> [5] <gs:cell row="1" col="1" inputValue="country"/>
as_list(xml_children(d)[[2]])
#> $id
#> $id[[1]]
#> [1] "A1"
#> 
#> 
#> $operation
#> list()
#> attr(,"type")
#> [1] "update"
#> 
#> $id
#> $id[[1]]
#> [1] "https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C1"
#> 
#> 
#> $link
#> list()
#> attr(,"rel")
#> [1] "edit"
#> attr(,"type")
#> [1] "application/atom+xml"
#> attr(,"href")
#> [1] "https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C1/fu9n6e"
#> 
#> $cell
#> list()
#> attr(,"row")
#> [1] "1"
#> attr(,"col")
#> [1] "1"
#> attr(,"inputValue")
#> [1] "country"
as_list(xml_children(rt)[[2]])
#> [[1]]
#> [1] "\n    "
#> 
#> $id
#> $id[[1]]
#> [1] "A1"
#> 
#> 
#> [[3]]
#> [1] "\n    "
#> 
#> $operation
#> list()
#> attr(,"type")
#> [1] "update"
#> 
#> [[5]]
#> [1] "\n    "
#> 
#> $id
#> $id[[1]]
#> [1] "https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C1"
#> 
#> 
#> [[7]]
#> [1] "\n    "
#> 
#> $link
#> list()
#> attr(,"rel")
#> [1] "edit"
#> attr(,"type")
#> [1] "application/atom+xml"
#> attr(,"href")
#> [1] "https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C1/fu9n6e"
#> 
#> [[9]]
#> [1] "\n    "
#> 
#> $cell
#> list()
#> attr(,"row")
#> [1] "1"
#> attr(,"col")
#> [1] "1"
#> attr(,"inputValue")
#> [1] "country"
#> 
#> [[11]]
#> [1] "\n  "

No, the linebreaks do cause problems!

But notice it doesn't affect XML written to file.

write_xml(rt, "27_feed-node-xml2-roundtrip.xml")
diff -b 27_feed-node-xml2.xml 27_feed-node-xml2-roundtrip.xml

Everything below here is old.

Here's my original rough pass at writing XML with xml2. Done with jimhester/xml2@04a83fe, which is now out-of-date. Code is not run.

feed <- xml_new_document() %>%
  xml_add_child("feed",
                xmlns = "http://www.w3.org/2005/Atom",
                "xmlns:batch" = "http://schemas.google.com/gdata/batch",
                "xmlns:gs" = "http://schemas.google.com/spreadsheets/2006"
  )
xml_add_child(feed, "id", africa_cellsfeed)
entry <- xml_add_child(feed, "entry")
xml_add_child(entry, "batch:id", update_fodder$cell[1])
xml_add_child(entry, "batch:operation", type = "update")
xml_add_child(entry, "id", update_fodder$cell_id[1])
xml_add_child(entry, "link", rel = "edit", type = "application/atom+xml",
              href = update_fodder$edit_link[1])
xml_add_child(entry, "gs:cell", row = as.character(update_fodder$row[1]),
              col = as.character(update_fodder$col[1]),
              inputValue = update_fodder$update_value[1])
## now I just need to do that for the remaining 35 rows of update_fodder :)
write_xml(feed, "27_feed-node-xml2.xml")

Observations about the XML vs xml2 result (other than the scale up)

  • Why no line breaks in the xml2 output? would be so much easier to look at
  • xml2 insists on adding <?xml version="1.0"?> as first line; will this matter? I have no idea
  • XML uses shorter form for elements with no content; I assume this is of no practical significance
  • xml2 requires me to explicitly convert things to character (see the row and col attributes of gs:cell node)

Re setting the namespaces: the current method feels a bit weird. It feels like I should be able to provide a character vector, with possibly one unnamed element (the first one?) for the default namespace. You might also expect that the output of xml_ns() could somehow be used to set namespace? But that does not work.

foo <- xml_add_child(xml_new_document(), "feed", xml_ns(feed))
#> Error in inherits(x, "xml_document"): object 'feed' not found
xml_ns(feed)
#> Error in inherits(x, "xml_document"): object 'feed' not found
xml_ns(foo)
#> Error in inherits(x, "xml_document"): object 'foo' not found
#' ---
#' output: github_document
#' ---
#+ setup, include = FALSE
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
error = TRUE
)
#' Task: create XML to update contents of cells in a Google Sheet.
#'
#' Here's how I currently do it with the XML package.
library(readr)
library(XML)
library(purrr)
update_fodder <- read_csv("27_update-fodder.csv")
africa_cellsfeed <- "SOME_URL"
f_XML <- function(cell, cell_id, edit_link, row, col, update_value) {
XML::xmlNode("entry",
XML::xmlNode("batch:id", cell),
XML::xmlNode("batch:operation",
attrs = c("type" = "update")),
XML::xmlNode("id", cell_id),
XML::xmlNode("link",
attrs = c("rel" = "edit",
"type" = "application/atom+xml",
"href" = edit_link)),
XML::xmlNode("gs:cell",
attrs = c("row" = row,
"col" = col,
"inputValue" = update_value)))
}
list_of_nodes <- update_fodder %>%
pmap(f_XML)
feed_node <-
xmlNode("feed",
namespaceDefinitions =
c("http://www.w3.org/2005/Atom",
batch = "http://schemas.google.com/gdata/batch",
gs = "http://schemas.google.com/spreadsheets/2006"),
.children = list(xmlNode("id", africa_cellsfeed))) %>%
addChildren(kids = list_of_nodes)
## here's what I actually send as body of an httr::POST request:
write(toString.XMLNode(feed_node), "27_feed-node-XML.xml")
#' Installing / verifying `xml2` from the relevant PR.
#+ xml2-setup
#devtools::install_github("hadley/xml2#76")
si <- devtools::session_info("xml2")$packages
si$source[si$package == "xml2"]
#' Current approach given by @jimhester.
#+ xml2-write
library(xml2)
d <- xml_new_document() %>%
xml_add_child("feed",
xmlns = "http://www.w3.org/2005/Atom",
"xmlns:batch" = "http://schemas.google.com/gdata/batch",
"xmlns:gs" = "http://schemas.google.com/spreadsheets/2006")
d %>% xml_add_child("id", africa_cellsfeed)
f_XML <- function(cell, cell_id, edit_link, row, col, update_value) {
d %>%
xml_add_child("entry") %>%
xml_add_child("batch:id", cell) %>%
xml_add_sibling("batch:operation", type = "update") %>%
xml_add_sibling("id", cell_id) %>%
xml_add_sibling("link", rel = "edit", type = "application/atom+xml",
href = edit_link) %>%
xml_add_sibling("gs:cell", row = as.character(row), col = as.character(col),
inputValue = update_value)
}
update_fodder %>% pwalk(f_XML)
write_xml(d, "27_feed-node-xml2.xml")
#' How does this compare to the output from the `XML` package? `xml2` adds an
#' XML declaration.
#+ xml-diff, engine='bash'
diff -b -U 0 27_feed-node-XML.xml 27_feed-node-xml2.xml
#' Can `xml2` roundtrip it's own XML? I.e. the new linebreaks don't cause
#' trouble? I wonder because of <https://github.com/hadley/xml2/issues/49>.
rt <- read_xml("27_feed-node-xml2.xml")
identical(as_list(d), as_list(rt))
head(all.equal(as_list(d), as_list(rt)))
xml_children(d)[[2]]
xml_children(rt)[[2]]
as_list(xml_children(d)[[2]])
as_list(xml_children(rt)[[2]])
#' No, the linebreaks do cause problems!
#'
#' But notice it doesn't affect XML written to file.
write_xml(rt, "27_feed-node-xml2-roundtrip.xml")
#+ xml2-diff, engine='bash'
diff -b 27_feed-node-xml2.xml 27_feed-node-xml2-roundtrip.xml
#' __Everything below here is old.__
#'
#' Here's my original rough pass at writing XML with xml2. Done with
#' jimhester/xml2@04a83fe, which is now out-of-date. Code is not run.
#+ xml2-first-pass, eval = FALSE
feed <- xml_new_document() %>%
xml_add_child("feed",
xmlns = "http://www.w3.org/2005/Atom",
"xmlns:batch" = "http://schemas.google.com/gdata/batch",
"xmlns:gs" = "http://schemas.google.com/spreadsheets/2006"
)
xml_add_child(feed, "id", africa_cellsfeed)
entry <- xml_add_child(feed, "entry")
xml_add_child(entry, "batch:id", update_fodder$cell[1])
xml_add_child(entry, "batch:operation", type = "update")
xml_add_child(entry, "id", update_fodder$cell_id[1])
xml_add_child(entry, "link", rel = "edit", type = "application/atom+xml",
href = update_fodder$edit_link[1])
xml_add_child(entry, "gs:cell", row = as.character(update_fodder$row[1]),
col = as.character(update_fodder$col[1]),
inputValue = update_fodder$update_value[1])
## now I just need to do that for the remaining 35 rows of update_fodder :)
write_xml(feed, "27_feed-node-xml2.xml")
#' Observations about the XML vs xml2 result (other than the scale up)
#'
#' * Why no line breaks in the xml2 output? would be so much easier to look at
#' * xml2 insists on adding `<?xml version="1.0"?>` as first line; will this
#' matter? I have no idea
#' * XML uses shorter form for elements with no content; I assume this is of no
#' practical significance
#' * xml2 requires me to explicitly convert things to character (see the row and
#' col attributes of gs:cell node)
#'
#' Re setting the namespaces: the current method feels a bit weird. It feels
#' like I should be able to provide a character vector, with possibly one
#' unnamed element (the first one?) for the default namespace. You might also
#' expect that the output of `xml_ns()` could somehow be used to set namespace?
#' But that does not work.
foo <- xml_add_child(xml_new_document(), "feed", xml_ns(feed))
xml_ns(feed)
xml_ns(foo)
cell row col edit_link cell_id update_value
A1 1 1 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C1/fu9n6e https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C1 country
B1 1 2 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C2/skdkms https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C2 continent
C1 1 3 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C3/m6lh9 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C3 year
D1 1 4 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C4/2ix4zl https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C4 lifeExp
E1 1 5 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C5/140rbl https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C5 pop
F1 1 6 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C6/ttswx4 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R1C6 gdpPercap
A2 2 1 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C1/cdj6rl https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C1 Algeria
B2 2 2 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C2/wo1nru https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C2 Africa
C2 2 3 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C3/kua4l https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C3 1952
D2 2 4 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C4/olavj5 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C4 43.077
E2 2 5 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C5/7ot21p https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C5 9279525
F2 2 6 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C6/emxr9d https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R2C6 2449.0082
A3 3 1 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C1/widqne https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C1 Angola
B3 3 2 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C2/wo5vh6 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C2 Africa
C3 3 3 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C3/ksvk5 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C3 1952
D3 3 4 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C4/p6lnb7 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C4 30.015
E3 3 5 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C5/59q5sf https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C5 4232095
F3 3 6 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C6/dsxy4s https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R3C6 3520.6103
A4 4 1 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C1/126nkg https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C1 Benin
B4 4 2 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C2/wo4gwq https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C2 Africa
C4 4 3 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C3/krgzp https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C3 1952
D4 4 4 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C4/oqzg8a https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C4 38.223
E4 4 5 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C5/1cdhnw https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C5 1738315
F4 4 6 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C6/qb9pxt https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R4C6 1062.7522
A5 5 1 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C1/17iysp https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C1 Botswana
B5 5 2 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C2/wnxg2i https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C2 Africa
C5 5 3 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C3/kq2f9 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C3 1952
D5 5 4 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C4/onmdxn https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C4 47.622
E5 5 5 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C5/qjynih https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C5 442308
F5 5 6 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C6/1pp67w https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R5C6 851.2411
A6 6 1 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C1/jsdcfb https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C1 Burkina Faso
B6 6 2 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C2/wnw1i2 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C2 Africa
C6 6 3 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C3/konut https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C3 1952
D6 6 4 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C4/p6vsqv https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C4 31.975
E6 6 5 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C5/8hjliw https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C5 4469979
F6 6 6 https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C6/8m4llm https://spreadsheets.google.com/feeds/cells/1tP1SAErOJbMrTTCONdL0a9lwe3KkhTuZaGhCy3MPZP8/ozf3txt/private/full/R6C6 543.2552
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment