forked from Jany-M/simple-csv-xls-exporter
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreadme.txt
333 lines (222 loc) · 12.5 KB
/
readme.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
=== Simple CSV/XLS Exporter ===
Contributors: Shambix, Dukessa, thaikolja, akforsyt
Author URL: https://www.shambix.com
Tags: csv, xls, export, excel, custom fields, custom post types, export products, export posts
Requires at least: 5
Tested up to: 5.9
Stable tag: trunk
License: GPLv2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Export any content to CSV or XLS, through a link/button, from backend / frontend. Supports custom post types, WooCommerce, custom taxonomies, post statuses, users & fields.
== Description ==
This plugin allows you to export your posts to CSV or XLS file, through a simple link/button, from either backend or frontend.
**Make sure you are using PHP 7.3+, if you see any errors, older versions will not be supported anymore. The plugin has been tested up to PHP 8.1.**
**Supports**
* any custom post type
* custom post status
* custom taxonomies
* custom fields
* WooCommerce products, orders, status, categories and fields
* export only current user posts
* export specific user ID posts
* export specific post IDs
You can set the default post type, with its taxonomies and custom fields, that you wish to export, from the Settings page.
After that, anytime you will use the urls `https://yoursite.com/?export=csv` for a CSV file, or `https://yoursite.com/?export=xls`, you will get that post type data.
"You must choose the post type and save the settings before you can see the taxonomies or custom fields for a custom post type. Once the page reloads, you will see the connected taxonomies and custom fields for the post type."
If you want to export from a different post type than the one saved in these settings, also from frontend, use the url `https://yoursite.com/?export=csv&post_type=your_post_type_slug` for a CSV file, or `https://yoursite.com/?export=xls&post_type=your_post_type_slug` to get a XLS.
**Please check the [Plugin's FAQ](https://wordpress.org/plugins/simple-csv-xls-exporter/#faq) for all possible options and available custom parameters you can use.**
When opening the exported xls, Excel will prompt the user with a warning, but the file is perfectly fine and can then be opened. Unfortunately this can't be avoided, [read more here](http://blogs.msdn.com/b/vsofficedeveloper/archive/2008/03/11/excel-2007-extension-warning.aspx).
= Questions? =
Check the FAQ before opening new threads in the forum!
> Contact me if you want a **custom version of the plugin**, for a fee (contact form at [shambix.com](http://www.shambix.com)).
* [Current Plugin on Github](https://github.com/Jany-M/simple-csv-xls-exporter)
= Credits =
* [Last forked plugin's version](https://github.com/mediebruket/custom-csv-exporter)
* [Original plugin's version](https://github.com/ethanhinson/custom-csv-exporter)
== Installation ==
1. Upload `simple-csv-xls-export.zip` to the `/wp-content/plugins/` directory
2. Activate the plugin through the 'Plugins' menu in WordPress
3. Go to Tools -> CSV/XLS Export to access the plugins settings and export files.
== Frequently Asked Questions ==
= How do I choose my post type, taxonomies and custom fields? =
Head over to the plugin's settings page, choose the post type. Then click "Save Changes" at the end of the page.
At this point, a list of the custom taxonomies and fields associated with that post type will appear.
Choose all of the fields you wish to export (use CTRL+click to select multiple ones) and click "Save Changes" again.
Then click on the "Export" buttons to get your CSV or XLS file.
= I don't see any custom fields on the Settings page. How come? =
You mush first choose your post type and click "Save Changes" before you can see a list of the associated custom fields.
Be sure to click "Save Changes" again in order to save your choices.
= Can I export to CSV from frontend? =
Yes, just place this URL where you want the download link/button to be: `<a class="btn" href="?export=csv">Export to CSV</a>`
This will export as per plugin Settings.
= Can I export to XLS from frontend? =
Yes, just place this URL where you want the download link/button to be: `<a class="btn" href="?export=xls">Export to XLS</a>`
This will export as per plugin Settings.
= Can I change the post type, from the frontend URL? =
Yes, use the URL var `?post_type=yourcustomposttypeslug`
Keep in mind however, that it will still look for the taxonomies and custom fields as per plugin Settings.
Eg. `https://yoursite.com/?export=xls&post_type=portfolio`
= Can I only export parents or children? =
Yes, use the URL var `?only=x`, where x is either `children` or `parents`.
Default is both.
Eg. `https://yoursite.com/?export=xls&post_type=portfolio&only=parents`
= Does it support cyrillic characters? (eg. Russian) =
Yes, but only for the CSV format (for now).
= Can I export only posts with a certain post status? =
Yes, as of v. 1.3.8.
You can set it up from the Settings page as default, or add to your url `?post_status=nameofstatus`
Eg. `https://yoursite.com/?export=xls&post_type=portfolio&post_status=draft`
= Can I export only posts from a specific user, or the current one? =
Yes, as of v. 1.4.
To export the file with content from the currently logged-in user, add this to your url `?user`
To export the file of a specific user ID, use this in your url `?user=x`, where X is the user ID you need.
Default is all users.
Eg. `https://yoursite.com/?export=xls&post_type=portfolio&user`
= Can I export specific posts? =
Yes, as of v. 1.5.
You need the parameter `?specific_posts` in the export url.
Eg. `https://yoursite.com/?export=xls&specific_posts=1,2,3`
= Can I export only posts from a specific date onward? =
Yes, as of v. 1.5.5.
To export the file with content created from a specific date, either use the global options or add this to your url `?date_min`
The date format, when using the url parameter, must be `mm-dd-yyyy`.
Eg. `https://yoursite.com/?export=csv&date_min=07-11-2020` (July 11 2020)
= Can I populate certain data in my export, in a custom way, through a filter? =
Yes, as of v. 1.5.7
Eg.
`function ccsve_generate_query_callback($query_arr) {
if (isset($_REQUEST['order_id']) && $_REQUEST['order_id']) {
$query_arr['meta_key'] = '_order_id';
$query_arr['meta_value'] = $_REQUEST['order_id'];
}
return $query_arr;
}
add_filter('ccsve_generate_query', 'ccsve_generate_query_callback');`
Where `order_id` is an assigned data to export, from plugin's options, `_order_id` is the name of the custom column you need and its value will be `order_id`.
Please remember to create your query according to [WP Query](https://developer.wordpress.org/reference/classes/wp_query/) guidelines.
Eg. If you want to add a custom date export, you will need to follow the same query construct shown [here](https://developer.wordpress.org/reference/classes/wp_query/#date-parameters).
For your own reference, you can find the original export query, and the filter hook, in [this](https://github.com/Jany-M/simple-csv-xls-exporter/blob/master/process/simple_csv_xls_exporter_csv_xls.php) plugin file.
= Can I populate certain data in my export, in a custom way, through a shortcode in the url parameter? =
Yes.
Eg.
This is a solution provided by Jayanta Sarkar, to generate custom post IDs through a function and then use the result as a shortcode, inside the export url, as a parameter value.
This url cannot be used directly however (copy and paste it in the browser url bar, it must be printed somewhere on a page of your website - backend or frontend).
`add_shortcode('search_post_ids', 'search_posts_function');
function search_posts_function(){
$search_term = $_GET['s'];
$args = array(
's' => $search_term,
'posts_per_page' => -1,
'post_type' => 'your_custom_post_type'
);
$query = new WP_Query( $args );
if ( $query->have_posts() ) {
while ( $query->have_posts() ) {
$query->the_post();
$ID_string .= get_the_ID().",";
}
}
return $ID_string;
}`
Adjust the above function to your needs.
Then use the shortcode in a url, like this:
`https://yoursite.com/?export=xls&specific_posts=[shortcode]`
== Screenshots ==
1. Settings Page
2. Settings Page
3. Settings Page
== Changelog ==
= 1.5.8 =
* Fixed bug in csv header (custom delimiter not working)
* Tested with WP 5.9
* Tested with PHP 8.1
* Added FAQs
= 1.5.7 =
* Add support for xls headers to be utf-8 decoded (thanks to [RubenMartins](https://github.com/Jany-M/simple-csv-xls-exporter/pull/3/commits/b4a98aa8853fe8edaf61b3ceaa9b77cc286845d0))
* Fix date_format and standardize to 'Y-m-d' format (thanks to [RubenMartins](https://github.com/Jany-M/simple-csv-xls-exporter/pull/4/commits/c68899e19703a8690c7d0fe01b1ef49760fbd46a))
* Add support to edit query via filter. Allow to change parameters via filter to for example add filter for meta_key/meta_value or other change to the query
. (thanks to [RubenMartins](https://github.com/Jany-M/simple-csv-xls-exporter/pull/5/commits/962295e7488c32a97e3b9b4903b01428ba3ce735))
= 1.5.6 =
* Re-introduced the `ccsve_export_returns` filter hook
= 1.5.5 =
* Added a Date global option, to export content only from that date onward
* Added `date_min` parameter (will override the global option)
* The export now ignores sticky posts
= 1.5.4.1 =
* Fixed PHP < 7 error: Argument 1 passed to simple_csv_xls_exporter_generate_file_name() must be an instance of string, string given.
* Plugin will only support PHP 7.3+ from now on.
= 1.5.3 =
* Pulled GabrielFalkoski's merge request
* Added a Hook Filter to handle content to export `ccsve_export_returns`
= 1.5.2 =
* Fix for "Warning: Use of undefined constant SIMPLE_CSV_EXPORTER_VERSION"
= 1.5.1 =
* Fixed action url from plugins page
* Fixed PHP syntax error (unexpected ?)
= 1.5 =
* Merged with thaikolja's fork and refactoring
* Added `specific_posts` parameter (Special thanks to: akforsyt)
= 1.4.9 =
* Plugin Refactoring (Special thanks to: thaikolja)
* Replaced spaces with tabs for intendation.
* Renamed classes (`SIMPLE_CSV_EXPORTER` to `Simple_CSV_Exporter`) to avoid confusion with constants.
* Added documentation to some functions and classes.
* Used strict comparison (`===`) where needed.
* Removed some comment areas used for development purposes.
* Added and rewrote some comments.
* Added textdomain and made several strings localizable.
* Restructured files, functions and classes and put them in appropriate directories.
* Renamed some constants to be more accurate.
* Added filter `simple_csv_xls_exporter_export_file_name`
= 1.4.6 =
* Added option to set custom Delimiter
* Fixed issue with html entities
= 1.4.5 =
* Fixed PHP 7.1 Fatal error 7.1 bug (Uncaught ArgumentCountError: Too few arguments to function do_settings_fields() )
= 1.4.4 =
* Minor fixes
= 1.4.3 =
* Set error_display to 0 during process
= 1.4.2 =
* Fixed bug *Parse error: syntax error, unexpected ‘[‘ in …./woo/wp-content/plugins/simple-csv-xls-exporter/process/simple_csv_xls_exporter_csv_xls.php on line 19*
= 1.4.1 =
* Added support for ANY post type (including internal/non-public ones)
* Added labels for post types instead of slug
* Added support for WooCommerce Orders
* Removed PHP format error above WP default fields settings box
= 1.4 =
* Added support for current user download
* Added support for specific user ID download
= 1.3.9.1 =
* Fixed a minor PHP notice
= 1.3.9 =
* Fixed bugs: `Illegal string offset ‘selectinput’ in simple-csv-xls-exporter\settings.php on line 147`, `in_array() expects parameter 2 to be array, string given in simple-csv-xls-exporter\settings.php on line 147`, `syntax error, unexpected ‘[‘ in simple-csv-xls-exporter/settings.php on line 157`
= 1.3.8 =
* Added support for Post Status
* Added option for Backend only export
* Minor Fixes
= 1.3.5 =
* Added support for WooCommerce
* Fixed some bugs when not finding any selected custom fields/taxonomies
* Fixed XLS not exporting correctly since 1.3.2
* Support for German characters for XLS and CSV
= 1.3.2 =
* Added url var to only export parents or children
* Added cyrillic characters support for CSV
* Restructured part of the plugin
* Saved options get removed when uninstalling plugin
= 1.3 =
* Fixed issue with new custom fields not showing
* Better caching of metas (24h)
= 1 =
* Added xls support
* Fixed bug with plugin not finding taxonomies during export because launched too early `(init->wp_loaded)`
= .4 =
* Fixed issue with SYLK format (ID in capital letters gives Excel error for CSV)
* Added url parameter `&post_type`, to use in stand-alone url
= .3 =
* Introduce taxonomy and default WordPress field export capabailities
= .2 =
* Fixed bug that limited number of posts that could be exported
= .1 =
* Initial release of plugin