我有这种格式的xml是自动创建的,并且想知道如何迭代它并将数据保存到mysql中
<sales>
<site_id="000001" sale_id="80" end_date="20170826" end_time="112420" />
<site_id="000002" sale_id="81" end_date="20170828" end_time="101001" />
<site_id="000003" sale_id="82" end_date="20170828" end_time="101001" />
</sales>
我可以插入到数据库中,但是它是迭代并捕获变量,我有点困惑
答案 0 :(得分:1)
这是一个无效的XML,它将是这样的:
<sales>
<sale site_id="000001" sale_id="80" end_date="20170826" end_time="112420"></sale>
<sale site_id="000002" sale_id="81" end_date="20170828" end_time="101001"></sale>
<sale site_id="000003" sale_id="82" end_date="20170828" end_time="101001"></sale>
</sales>
$dom = new DOMDocument('1.0', 'utf-8');
$dom->loadXML($xml);
$xpath = new DOMXpath($dom);
$a = $xpath->query("//sale");
$result = array();
$i = 0;
foreach($a as $b)
{
if ($b->hasAttributes())
{
$j = 0;
$tmp = array();
foreach ($b->attributes as $attr)
{
$tmp[$attr->nodeName] = $attr->nodeValue;
$j++;
}
$result[] = $tmp;
}
$i++;
}
print_r($result);
`
输出:
Array
(
[0] => Array
(
[site_id] => 000001
[sale_id] => 80
[end_date] => 20170826
[end_time] => 112420
)
[1] => Array
(
[site_id] => 000002
[sale_id] => 81
[end_date] => 20170828
[end_time] => 101001
)
[2] => Array
(
[site_id] => 000003
[sale_id] => 82
[end_date] => 20170828
[end_time] => 101001
)
)
答案 1 :(得分:1)
如果您无法编辑源代码,则可以使用正则表达式:
<?php
// Exit if accessed directly
if ( ! defined( 'ABSPATH' ) ) exit;
if ( ! class_exists( 'Wrestleefedmanager_Federation' ) ) :
class Wrestleefedmanager_Federation {
/**
* Constructor
*/
public function __construct() {
// Hooking up our function to theme setup
add_action( 'init', array( $this, 'create_federation_post_type' ) );
//add_action( 'add_meta_boxes', array( $this, 'initialize_federation_post_type') );
add_action( 'save_post', array( $this, 'save_fed') );
add_filter ('template_include', array($this, 'display_federation_template' ) );
}
// Our custom post type function
function create_federation_post_type() {
$fedlabels = array(
'name' => _x( 'Federations', 'Post Type General Name'),
'singular_name' => _x( 'Federation', 'Post Type Singular Name'),
'menu_name' => __( 'Federations'),
'parent_item_colon' => __( 'Parent Fed'),
'all_items' => __( 'All Feds'),
'view_item' => __( 'View Fed'),
'add_new_item' => __( 'Add New Fed'),
'add_new' => __( 'Add New'),
'edit_item' => __( 'Edit Fed'),
'update_item' => __( 'Update Fed'),
'search_items' => __( 'Search Feds'),
'not_found' => __( 'Not Found'),
'not_found_in_trash' => __( 'Not found in Trash'),
);
$fedargs = array(
'label' => __( 'Federations' ),
'description' => __( 'Wrestling Companies' ),
'labels' => $fedlabels,
// Features this CPT supports in Post Editor
'supports' => array( 'title', 'editor', 'author', ),
// You can associate this CPT with a taxonomy or custom taxonomy.
//'taxonomies' => array( 'genres' ),
/* A hierarchical CPT is like Pages and can have
* Parent and child items. A non-hierarchical CPT
* is like Posts.
*/
'hierarchical' => true,
'public' => true,
'show_ui' => true,
'show_in_menu' => true,
'show_in_nav_menus' => true,
'show_in_admin_bar' => true,
'menu_position' => 17,
'can_export' => true,
'has_archive' => true,
'exclude_from_search' => false,
'publicly_queryable' => true,
'capability_type' => 'page',
'register_meta_box_cb' => array( $this, 'initialize_federation_post_type'),
);
register_post_type( 'feds', $fedargs);
}
function initialize_federation_post_type() {
/*
add_meta_box( string $id, string $title, callable $callback, string|array|WP_Screen $screen = null,
string $context = 'advanced', string $priority = 'default', array $callback_args = null )*/
add_meta_box("abbreviation", "Abbreviation", array( $this, 'fed_abbr'), "feds", "normal", "low");
add_meta_box("founded", "Founded", array( $this, 'fed_founded'), "feds", "side", "low");
add_meta_box("closed", "Closed", array( $this, 'fed_closed'), "feds", "side", "low");
add_meta_box("parentfed", "Parent Federation", array( $this, 'fed_parent'), "feds", "normal", "low");
add_meta_box("logo", "Logo", array( $this, 'fed_logo'), "feds", "normal", "low");
add_meta_box("owner", "Owner", array( $this, 'fed_owner'), "feds", "side", "low");
}
function fed_abbr(){
global $post;
$custom = get_post_custom($post->ID);
$abbr = $custom["abbreviation"][0];
?>
<label>Abbr:</label>
<input name="fed_abbreviation" type="text" value="<?php echo $abbr; ?>" />
<?php
}
function fed_founded(){
global $post;
$custom = get_post_custom($post->ID);
$founded = $custom["founded"][0];
?>
<label>Founded:</label>
<input name="fed_founddate" value="<?php echo $founded; ?>" />
<?php
}
function fed_closed(){
global $post;
$custom = get_post_custom($post->ID);
$closed = $custom["closed"][0];
?>
<label>Closed:</label>
<input name="fed_closedate" value="<?php echo $closed; ?>" />
<?php
}
function fed_parent(){
}
function fed_logo(){
}
function fed_owner(){
global $post;
$custom = get_post_custom($post->ID);
$owner = $custom["owner"][0];
?>
<label>Owner:</label>
<input name="fed_owner" value="<?php echo $owner; ?>" />
<?php
}
function save_fed(){
global $post;
update_post_meta($post->ID, "abbreviation", $_POST["fed_abbreviation"]);
update_post_meta($post->ID, "founded", $_POST["fed_founddate"]);
update_post_meta($post->ID, "closed", $_POST["fed_closedate"]);
update_post_meta($post->ID, "owner", $_POST["fed_owner"]);
}
function display_federation_template ($template_path) {
if ( get_post_type() == 'feds' ) {
if ( is_single() ) {
// checks if the file exists in the theme first,
// otherwise serve the file from the plugin
if ( $theme_file = locate_template( array ( 'single-feds.php' ) ) ) {
$template_path = $theme_file;
} else {
$template_path = plugin_dir_path( __FILE__ ) . '/single-feds.php';
}
}
}
return $template_path;
}
}
endif;
PD:杀死XML源开发者