0

我想在 www.mysamplewebsite.com/wp-admin/users.php 页面的用户列表页面上添加名为“导出”的新链接。如果用户点击它,它应该将所有添加的用户导出为 csv 或 excel格式。

我已经搜索过插件,但都允许在不同的菜单中做这件事,但根据客户的要求,我需要遵循这个..

我们有任何可用的 wordpress 钩子或其他任何我可以实现这些东西的东西吗?我已经四处搜索,但尚未根据 wordpress 流程找到合适的解决方案。

有人可以帮助我使用任何 wordpress 钩子或其他东西来实现这件事吗...

期待 ..

谢谢

4

2 回答 2

7

我认为这应该这样做:

<?php

/********* Export to csv ***********/
add_action('admin_footer', 'mytheme_export_users');

function mytheme_export_users() {
    $screen = get_current_screen();
    if ( $screen->id != "users" )   // Only add to users.php page
        return;
    ?>
    <script type="text/javascript">
        jQuery(document).ready( function($)
        {
            $('.tablenav.top .clear, .tablenav.bottom .clear').before('<form action="#" method="POST"><input type="hidden" id="mytheme_export_csv" name="mytheme_export_csv" value="1" /><input class="button button-primary user_export_button" style="margin-top:3px;" type="submit" value="<?php esc_attr_e('Export All as CSV', 'mytheme');?>" /></form>');
        });
    </script>
    <?php
}

add_action('admin_init', 'export_csv'); //you can use admin_init as well

function export_csv() {
    if (!empty($_POST['mytheme_export_csv'])) {

        if (current_user_can('manage_options')) {
            header("Content-type: application/force-download");
            header('Content-Disposition: inline; filename="users'.date('YmdHis').'.csv"');

            // WP_User_Query arguments
            $args = array (
                'order'          => 'ASC',
                'orderby'        => 'display_name',
                'fields'         => 'all',
            );

            // The User Query
            $blogusers = get_users( $args );
            // Array of WP_User objects.
            foreach ( $blogusers as $user ) {
                $meta = get_user_meta($user->ID);
                $role = $user->roles;
                $email = $user->user_email;

                $first_name = ( isset($meta['first_name'][0]) && $meta['first_name'][0] != '' ) ? $meta['first_name'][0] : '' ;
                $last_name  = ( isset($meta['last_name'][0]) && $meta['last_name'][0] != '' ) ? $meta['last_name'][0] : '' ;

                echo '"' . $first_name . '","' . $last_name . '","' . $email . '","' . ucfirst($role[0]) . '"' . "\r\n";
            }

            exit();
        }
    }
}

第一部分将在 users 表的页眉和页脚中向表导航添加一个按钮。当您单击它时,您将调用export_csv()下面的函数。当然,您可以根据自己的喜好对其进行自定义。

希望这可以帮助 :)

于 2016-08-08T06:48:40.970 回答